jupyterlab-git


Namejupyterlab-git JSON
Version 0.50.0 PyPI version JSON
download
home_page
SummaryA JupyterLab extension for version control using git
upload_time2023-11-21 14:39:02
maintainer
docs_urlNone
authorJupyter Development Team
requires_python>=3.8
licenseBSD 3-Clause License Copyright (c) 2020, Jupyter Development Team All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # jupyterlab-git

[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/jupyterlab/jupyterlab-git/main?urlpath=lab/tree/examples/demo.ipynb) [![Github Actions Status](https://github.com/jupyterlab/jupyterlab-git/actions/workflows/build.yml/badge.svg)](https://github.com/jupyterlab/jupyterlab-git/actions/workflows/build.yml) [![Version](https://img.shields.io/npm/v/@jupyterlab/git.svg)](https://www.npmjs.com/package/@jupyterlab/git) [![Version](https://img.shields.io/pypi/v/jupyterlab-git.svg)](https://pypi.org/project/jupyterlab-git/) [![Downloads](https://img.shields.io/npm/dm/@jupyterlab/git.svg)](https://www.npmjs.com/package/@jupyterlab/git) [![Version](https://img.shields.io/conda/vn/conda-forge/jupyterlab-git.svg)](https://anaconda.org/conda-forge/jupyterlab-git) [![Downloads](https://img.shields.io/conda/dn/conda-forge/jupyterlab-git.svg)](https://anaconda.org/conda-forge/jupyterlab-git)<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->
[![All Contributors](https://img.shields.io/badge/all_contributors-30-orange.svg?style=flat-square)](#contributors-)

<!-- ALL-CONTRIBUTORS-BADGE:END -->

A JupyterLab extension for version control using Git

![ui_glow_up](https://raw.githubusercontent.com/jupyterlab/jupyterlab-git/main/docs/figs/preview.gif)

To see the extension in action, open the example notebook included in the Binder [demo](https://mybinder.org/v2/gh/jupyterlab/jupyterlab-git/main?urlpath=lab/tree/examples/demo.ipynb).

## Requirements

- JupyterLab >= 4.0 ([older version] available for 2.x)
- Git (version `>=2.x`)

For older versions of JupyterLab, go to:

- [3.x branch](https://github.com/jupyterlab/jupyterlab-git/tree/jlab-3)
- [2.x branch](https://github.com/jupyterlab/jupyterlab-git/tree/jlab-2)

## Usage

- Open the Git extension from the _Git_ tab on the left panel
- [Set up authentication](#authentication-to-remote-repository-hosts)

## Install

To install perform the following steps, with _pip_:

```bash
pip install --upgrade "jupyterlab<4" jupyterlab-git
```

or with _conda_:

```bash
conda install -c conda-forge "jupyterlab<4" jupyterlab-git
```

## Uninstall

To remove the extension, execute:

```bash
pip uninstall jupyterlab_git
```

or with _conda_:

```bash
conda remove jupyterlab-git
```

## Settings

### Authentication to remote repository hosts

If you are seeing errors similar to `[E yyyy-mm-dd hh:mm:ss ServerApp] 500 POST /git/<clone|push|pull|status>` on the console which is running the JupyterLab server, you probably need to set up a credentials store for your local Git repository.

This extension tries to handle credentials for HTTP(S) connections (if you don't have set up a credential manager). But not for other SSH connections.

> For Windows users, it is recommended to install [git for windows](https://gitforwindows.org/). It will automatically set up a credential manager.
> In order to connect to a remote host, it is recommended to use SSH.

#### HTTP(S) protocol

The extension can cache temporarily (by default for an hour) credentials. To use the caching, you will need to
check the option _Save my login temporarily_ in the dialog asking your credentials.

> You can set a longer cache timeout; see [Server Settings](#server-settings).

> This is a new feature since v0.37.0

#### SSH protocol

Here are the steps to follow to set up SSH authentication (skip any that is already accomplished for your project):

1. [Create a SSH key](https://docs.github.com/en/github/authenticating-to-github/connecting-to-github-with-ssh/generating-a-new-ssh-key-and-adding-it-to-the-ssh-agent)
2. Register the public part of it to your Git server:
   - [GitHub](https://docs.github.com/en/github/authenticating-to-github/connecting-to-github-with-ssh/adding-a-new-ssh-key-to-your-github-account)
   - [GitLab](https://docs.gitlab.com/ee/ssh/index.html#add-an-ssh-key-to-your-gitlab-account)
3. Optionally, if you have more than one key managed by your ssh agent: [Create a config file for the ssh-agent](https://stackoverflow.com/a/21938804)
4. Tell your local Git repository to [connect to remote via ssh](https://docs.github.com/en/get-started/getting-started-with-git/managing-remote-repositories#switching-remote-urls-from-https-to-ssh)

You should now be able to pull and push committed changes to and from your remote repository using the respective buttons on the top of the extension's panel.

### UI Settings

Once installed, extension behavior can be modified via the following settings which can be set in JupyterLab's advanced settings editor:

- **blockWhileCommandExecutes**: suspend JupyterLab user interaction until Git commands (e.g., `commit`, `pull`, `reset`, `revert`) finish executing. Setting this to `true` helps mitigate potential race conditions leading to data loss, conflicts, and a broken Git history. Unless running a slow network, UI suspension should not interfere with standard workflows. Setting this to `false` allows for actions to trigger multiple concurrent Git actions.
- **cancelPullMergeConflict**: cancel pulling changes from a remote repository if there exists a merge conflict. If set to `true`, when fetching and integrating changes from a remote repository, a conflicting merge is canceled and the working tree left untouched.
- **commitAndPush**: Whether to trigger or not a push for each commit; default is `false`.
- **disableBranchWithChanges**: disable all branch operations, such as creating a new branch or switching to a different branch, when there are changed/staged files. When set to `true`, this setting guards against overwriting and/or losing uncommitted changes.
- **displayStatus**: display Git extension status updates in the JupyterLab status bar. If `true`, the extension displays status updates in the JupyterLab status bar, such as when pulling and pushing changes, switching branches, and polling for changes. Depending on the level of extension activity, some users may find the status updates distracting. In which case, setting this to `false` should reduce visual noise.
- **doubleClickDiff**: double click a file in the Git extension panel to open a diff of the file instead of opening the file for editing.
- **historyCount**: number of commits shown in the history log, beginning with the most recent. Displaying a larger number of commits can lead to performance degradation, so use caution when modifying this setting.
- **promptUserIdentity**: Whether to prompt for user name and email on every commit.
- **refreshIfHidden**: whether to refresh even if the Git tab is hidden; default to `false` (i.e. refresh is turned off if the Git tab is hidden).
- **refreshInterval**: number of milliseconds between polling the file system for changes. In order to ensure that the UI correctly displays the current repository status, the extension must poll the file system for changes. Longer polling times increase the likelihood that the UI does not reflect the current status; however, longer polling times also incur less performance overhead.
- **simpleStaging**: enable a simplified concept of staging. When this setting is `true`, all files with changes are automatically staged. When we develop in JupyterLab, we often only care about what files have changed (in the broadest sense) and don't need to distinguish between "tracked" and "untracked" files. Accordingly, this setting allows us to simplify the visual presentation of changes, which is especially useful for those less acquainted with Git.

### Server Settings

- `JupyterLabGit.actions.post_init`: Set post _git init_ actions.
  It is possible to provide a list of commands to be executed in a folder after it is initialized as Git repository.
- `JupyterLabGit.credential_helper`: Git credential helper to set to cache the credentials.
  The default value is `cache --timeout=3600` to cache the credentials for an hour. If you want to cache them for 10 hours, set `cache --timeout=36000`.
- `JupyterLabGit.excluded_paths`: Set path patterns to exclude from this extension. You can use wildcard and interrogation mark for respectively everything or any single character in the pattern.
- `JupyterLabGit.git_command_timeout_s`: Set the timeout for git operations. Defaults to 20 seconds.
<details>
<summary><b>How to set server settings?</b></summary>

In `$HOME/.jupyter/jupyter_notebook_config.py` (on Windows `%USERPROFILE%/.jupyter/jupyter_notebook_config.py`):

```python
c.JupyterLabGit.actions = {"post_init": ["touch dummy_init.dat"]}
c.JupyterLabGit.credential_helper = 'cache --timeout=3600'
```

Or equivalently in `$HOME/.jupyter/jupyter_notebook_config.json` (on Windows `%USERPROFILE%/.jupyter/jupyter_notebook_config.json`):

```json
{
  "JupyterLabGit": {
    "actions": {
      "post_init": ["touch dummy_init.dat"]
    },
    "credential_helper": "cache --timeout=3600"
  }
}
```

</details>

## Troubleshoot

If you are seeing the frontend extension, but it is not working, check
that the server extension is enabled:

```bash
jupyter server extension list
```

If the server extension is installed and enabled, but you are not seeing
the frontend extension, check the frontend extension is installed:

```bash
jupyter labextension list
```

If they do not match or one is missing, please [reinstall the package](README.md#Install).

<details><summary>the Git panel does not recognize that you are in a Git repository.</summary>

Possible fixes:

- Be sure to be in a Git repository in the filebrowser tab

- Check the server log. If you see a warning with a 404 code similar to:
  `[W 00:27:41.800 LabApp] 404 GET /git/settings?version=0.20.0`

  Explicitly enable the server extension by running:

  ```bash
  jupyter server extension enable --py jupyterlab_git
  ```

- If you are using JupyterHub or some other technologies requiring an initialization script which includes the jupyterlab-git extension, be sure to install both the frontend and the server extension **before** launching JupyterLab.
</details>

<details>
<summary>the Git panel is not visible.</summary>

Possible fixes:

- Check that the JupyterLab extension is installed:

      ```bash
      jupyter labextension list
      ```

      If you don't see `@jupyterlab/git v... enabled OK` in the list, explicitly install the jupyter labextension by running:

      ```bash
      jupyter labextension install @jupyterlab/git
      ```

      If you see `@jupyterlab/git` under `Uninstalled core extensions: `, your installation may have been corrupted. You can run `jupyter lab clean --all` and
      reinstall all your extensions.

</details>

## Contributing

If you would like to contribute to the project, please read our [contributor documentation](https://github.com/jupyterlab/jupyterlab/blob/main/CONTRIBUTING.md).

JupyterLab follows the official [Jupyter Code of Conduct](https://github.com/jupyter/governance/blob/main/conduct/code_of_conduct.md).

### Development install

Note: You will need NodeJS to build the extension package.

The `jlpm` command is JupyterLab's pinned version of
[yarn](https://yarnpkg.com/) that is installed with JupyterLab. You may use
`yarn` or `npm` in lieu of `jlpm` below.

```bash
# Clone the repo to your local environment
git clone https://github.com/jupyterlab/jupyterlab-git.git
# Change directory to the jupyterlab-git directory
cd jupyterlab-git
# Install package in development mode
pip install -e ".[dev,test]"
pre-commit install
# Link your development version of the extension with JupyterLab
jupyter labextension develop . --overwrite
# Server extension must be manually installed in develop mode
jupyter server extension enable jupyterlab_git
# Rebuild extension Typescript source after making changes
jlpm run build
```

You can watch the source directory and run JupyterLab at the same time in different terminals to watch for changes in the extension's source and automatically rebuild the extension.

```bash
# Watch the source directory in one terminal, automatically rebuilding when needed
jlpm run watch
# Run JupyterLab in another terminal
jupyter lab
```

With the watch command running, every saved change will immediately be built locally and available in your running JupyterLab. Refresh JupyterLab to load the change in your browser (you may need to wait several seconds for the extension to be rebuilt).

By default, the `jlpm run build` command generates the source maps for this extension to make it easier to debug using the browser dev tools. To also generate source maps for the JupyterLab core extensions, you can run the following command:

```bash
jupyter lab build --minimize=False
```

### Development uninstall

```bash
# Server extension must be manually disabled in develop mode
jupyter server extension disable jupyterlab_git
pip uninstall jupyterlab_git
```

In development mode, you will also need to remove the symlink created by `jupyter labextension develop`
command. To find its location, you can run `jupyter labextension list` to figure out where the `labextensions`
folder is located. Then you can remove the symlink named `@jupyterlab/git` within that folder.

### Testing the extension

#### Server tests

This extension is using [Pytest](https://docs.pytest.org/) for Python code testing.

Install test dependencies (needed only once):

```sh
pip install -e ".[test]"
# Each time you install the Python package, you need to restore the front-end extension link
jupyter labextension develop . --overwrite
```

To execute them, run:

```sh
pytest -vv -r ap --cov jupyterlab_git
```

#### Frontend tests

This extension is using [Jest](https://jestjs.io/) for JavaScript code testing.

To execute them, execute:

```sh
jlpm
jlpm test
```

#### Integration tests

This extension uses [Playwright](https://playwright.dev/docs/intro) for the integration tests (aka user level tests).
More precisely, the JupyterLab helper [Galata](https://github.com/jupyterlab/jupyterlab/tree/master/galata) is used to handle testing the extension in JupyterLab.

More information are provided within the [ui-tests](./ui-tests/README.md) README.

### Packaging the extension

See [RELEASE](RELEASE.md)

## Contributors ✨

The Jupyter Git extension is part of [Project Jupyter](http://jupyter.org/) and is developed by an open community of contributors. To see who has been active recently, please look at the ["Contributors"](https://github.com/jupyterlab/jupyterlab-git/graphs/contributors) tab. Below we list the people and entities who contributed in different ways to the project ([emoji key](https://allcontributors.org/docs/en/emoji-key)):

<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->
<!-- prettier-ignore-start -->
<!-- markdownlint-disable -->
<table>
  <tbody>
    <tr>
      <td align="center" valign="top" width="14.28%"><a href="https://amazon.com/aws"><img src="https://avatars3.githubusercontent.com/u/2232217?v=4?s=100" width="100px;" alt="Amazon Web Services"/><br /><sub><b>Amazon Web Services</b></sub></a><br /><a href="#financial-aws" title="">🀝</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/ashutoshbondre"><img src="https://avatars0.githubusercontent.com/u/13174154?v=4?s=100" width="100px;" alt="Ashutosh Bondre"/><br /><sub><b>Ashutosh Bondre</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=ashutoshbondre" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aashutoshbondre" title="Reviewed Pull Requests">πŸ‘€</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/stdlib-js/stdlib"><img src="https://avatars0.githubusercontent.com/u/2643044?v=4?s=100" width="100px;" alt="Athan"/><br /><sub><b>Athan</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=kgryte" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Akgryte" title="Reviewed Pull Requests">πŸ‘€</a> <a href="#projectManagement-kgryte" title="Project Management">πŸ“†</a> <a href="#design-kgryte" title="Design">🎨</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://basokant.com"><img src="https://avatars.githubusercontent.com/u/70033855?v=4?s=100" width="100px;" alt="Ben Asokanthan"/><br /><sub><b>Ben Asokanthan</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=basokant" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/BoscoCHW"><img src="https://avatars.githubusercontent.com/u/45115214?v=4?s=100" width="100px;" alt="Bosco Chan"/><br /><sub><b>Bosco Chan</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=BoscoCHW" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/ellisonbg"><img src="https://avatars3.githubusercontent.com/u/27600?v=4?s=100" width="100px;" alt="Brian E. Granger"/><br /><sub><b>Brian E. Granger</b></sub></a><br /><a href="#projectManagement-ellisonbg" title="Project Management">πŸ“†</a> <a href="#design-ellisonbg" title="Design">🎨</a> <a href="#ideas-ellisonbg" title="Ideas, Planning, & Feedback">πŸ€”</a> <a href="#fundingFinding-ellisonbg" title="Funding Finding">πŸ”</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/Damans227"><img src="https://avatars.githubusercontent.com/u/61474540?v=4?s=100" width="100px;" alt="Daman Arora"/><br /><sub><b>Daman Arora</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=Damans227" title="Code">πŸ’»</a></td>
    </tr>
    <tr>
      <td align="center" valign="top" width="14.28%"><a href="https://dquach.dev"><img src="https://avatars.githubusercontent.com/u/6735818?v=4?s=100" width="100px;" alt="Dat Quach"/><br /><sub><b>Dat Quach</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=quachtridat" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/fcollonval"><img src="https://avatars1.githubusercontent.com/u/8435071?v=4?s=100" width="100px;" alt="Frédéric Collonval"/><br /><sub><b>Frédéric Collonval</b></sub></a><br /><a href="#maintenance-fcollonval" title="Maintenance">🚧</a></td>
      <td align="center" valign="top" width="14.28%"><img src="https://avatars1.githubusercontent.com/u/27518229?v=4?s=100" width="100px;" alt="Hana Zarea"/><br /><sub><b>Hana Zarea</b></sub><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=hzarea" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Ahzarea" title="Reviewed Pull Requests">πŸ‘€</a></td>
      <td align="center" valign="top" width="14.28%"><a href="http://ianhi.github.io"><img src="https://avatars0.githubusercontent.com/u/10111092?v=4?s=100" width="100px;" alt="Ian Hunt-Isaak"/><br /><sub><b>Ian Hunt-Isaak</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=ianhi" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aianhi" title="Reviewed Pull Requests">πŸ‘€</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/jaipreet-s"><img src="https://avatars1.githubusercontent.com/u/43826141?v=4?s=100" width="100px;" alt="Jaipreet Singh"/><br /><sub><b>Jaipreet Singh</b></sub></a><br /><a href="#projectManagement-jaipreet-s" title="Project Management">πŸ“†</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Ajaipreet-s" title="Reviewed Pull Requests">πŸ‘€</a> <a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=jaipreet-s" title="Code">πŸ’»</a> <a href="#design-jaipreet-s" title="Design">🎨</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/zzhangjii"><img src="https://avatars3.githubusercontent.com/u/11495372?v=4?s=100" width="100px;" alt="Ji Zhang"/><br /><sub><b>Ji Zhang</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=zzhangjii" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Azzhangjii" title="Reviewed Pull Requests">πŸ‘€</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/kentarolim10"><img src="https://avatars.githubusercontent.com/u/61769040?v=4?s=100" width="100px;" alt="Kentaro Lim"/><br /><sub><b>Kentaro Lim</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=kentarolim10" title="Code">πŸ’»</a></td>
    </tr>
    <tr>
      <td align="center" valign="top" width="14.28%"><a href="http://taletskiy.com"><img src="https://avatars0.githubusercontent.com/u/8834829?v=4?s=100" width="100px;" alt="Konstantin Taletskiy"/><br /><sub><b>Konstantin Taletskiy</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=ktaletsk" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aktaletsk" title="Reviewed Pull Requests">πŸ‘€</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://kostyafarber.github.io/"><img src="https://avatars.githubusercontent.com/u/73378227?v=4?s=100" width="100px;" alt="Kostya Farber"/><br /><sub><b>Kostya Farber</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=kostyafarber" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://www.lindaful.com"><img src="https://avatars.githubusercontent.com/u/68607795?v=4?s=100" width="100px;" alt="Linda Ngoc Nguyen"/><br /><sub><b>Linda Ngoc Nguyen</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=iflinda" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://fellowship.mlh.io/"><img src="https://avatars.githubusercontent.com/u/65834464?s=200&v=4?s=100" width="100px;" alt="Major League Hacking"/><br /><sub><b>Major League Hacking</b></sub></a><br /><a href="#financial-mlh" title="">🀝</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://www.linkedin.com/in/max-klein-b514419"><img src="https://avatars2.githubusercontent.com/u/2263641?v=4?s=100" width="100px;" alt="Max Klein"/><br /><sub><b>Max Klein</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=telamonian" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Atelamonian" title="Reviewed Pull Requests">πŸ‘€</a> <a href="#projectManagement-telamonian" title="Project Management">πŸ“†</a> <a href="#design-telamonian" title="Design">🎨</a> <a href="#infra-telamonian" title="Infrastructure (Hosting, Build-Tools, etc)">πŸš‡</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://www.linkedin.com/in/michal-krassowski/"><img src="https://avatars.githubusercontent.com/u/5832902?v=4?s=100" width="100px;" alt="MichaΕ‚ Krassowski"/><br /><sub><b>MichaΕ‚ Krassowski</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=krassowski" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Akrassowski" title="Reviewed Pull Requests">πŸ‘€</a> <a href="https://github.com/jupyterlab/jupyterlab-git/issues?q=author%3Akrassowski" title="Bug reports">πŸ›</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://navn.me"><img src="https://avatars.githubusercontent.com/u/59669957?v=4?s=100" width="100px;" alt="Navinn Ravindaran"/><br /><sub><b>Navinn Ravindaran</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=navn-r" title="Code">πŸ’»</a></td>
    </tr>
    <tr>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/neelamgehlot"><img src="https://avatars2.githubusercontent.com/u/15882916?v=4?s=100" width="100px;" alt="Neelam Gehlot"/><br /><sub><b>Neelam Gehlot</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=neelamgehlot" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aneelamgehlot" title="Reviewed Pull Requests">πŸ‘€</a></td>
      <td align="center" valign="top" width="14.28%"><a href="http://noahstapp.com/"><img src="https://avatars0.githubusercontent.com/u/30483654?v=4?s=100" width="100px;" alt="Noah Stapp"/><br /><sub><b>Noah Stapp</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=NoahStapp" title="Code">πŸ’»</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3ANoahStapp" title="Reviewed Pull Requests">πŸ‘€</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://www.saulshanabrook.com/"><img src="https://avatars1.githubusercontent.com/u/1186124?v=4?s=100" width="100px;" alt="Saul Shanabrook"/><br /><sub><b>Saul Shanabrook</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=saulshanabrook" title="Code">πŸ’»</a> <a href="#projectManagement-saulshanabrook" title="Project Management">πŸ“†</a> <a href="https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Asaulshanabrook" title="Reviewed Pull Requests">πŸ‘€</a> <a href="#infra-saulshanabrook" title="Infrastructure (Hosting, Build-Tools, etc)">πŸš‡</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/shawnesquivel"><img src="https://avatars.githubusercontent.com/u/94336773?v=4?s=100" width="100px;" alt="Shawn Esquivel"/><br /><sub><b>Shawn Esquivel</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=shawnesquivel" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="http://sheezaaziz.com"><img src="https://avatars.githubusercontent.com/u/47278108?v=4?s=100" width="100px;" alt="Sheeza Aziz"/><br /><sub><b>Sheeza Aziz</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=sheezaaziz" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="http://sinakhalili.com"><img src="https://avatars.githubusercontent.com/u/20732540?v=4?s=100" width="100px;" alt="Sina Khalili"/><br /><sub><b>Sina Khalili</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=SinaKhalili" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://www.deshaw.com/"><img src="https://avatars0.githubusercontent.com/u/2298205?v=4?s=100" width="100px;" alt="The D. E. Shaw Group"/><br /><sub><b>The D. E. Shaw Group</b></sub></a><br /><a href="#financial-deshaw" title="">🀝</a></td>
    </tr>
    <tr>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/ZeshanFayyaz"><img src="https://avatars.githubusercontent.com/u/43391249?v=4?s=100" width="100px;" alt="Zeshan Fayyaz"/><br /><sub><b>Zeshan Fayyaz</b></sub></a><br /><a href="https://github.com/jupyterlab/jupyterlab-git/commits?author=ZeshanFayyaz" title="Code">πŸ’»</a></td>
      <td align="center" valign="top" width="14.28%"><a href="https://github.com/jupytercalpoly"><img src="https://avatars0.githubusercontent.com/u/19445175?v=4?s=100" width="100px;" alt="jupytercalpoly"/><br /><sub><b>jupytercalpoly</b></sub></a><br /><a href="#financial-jupytercalpoly" title="">🀝</a></td>
    </tr>
  </tbody>
</table>

<!-- markdownlint-restore -->
<!-- prettier-ignore-end -->

<!-- ALL-CONTRIBUTORS-LIST:END -->

This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind are welcomed!

To add yourself, or someone else, to this list you can either [use the bot](https://allcontributors.org/docs/en/bot/usage) (`@all-contributors please add <username> for <contributions>`) or [the CLI](https://allcontributors.org/docs/en/cli/usage) (`jlpm all-contributors add <username> <contributions>`).

If you manually edit the `.all-contributorsrc` config file, run `yarn run contributors:generate`.

            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "jupyterlab-git",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": "",
    "keywords": "",
    "author": "Jupyter Development Team",
    "author_email": "",
    "download_url": "https://files.pythonhosted.org/packages/49/00/75df0ae290fea477232fd8f53dd71720366b54d5546ca313671cef5dde78/jupyterlab_git-0.50.0.tar.gz",
    "platform": null,
    "description": "# jupyterlab-git\n\n[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/jupyterlab/jupyterlab-git/main?urlpath=lab/tree/examples/demo.ipynb) [![Github Actions Status](https://github.com/jupyterlab/jupyterlab-git/actions/workflows/build.yml/badge.svg)](https://github.com/jupyterlab/jupyterlab-git/actions/workflows/build.yml) [![Version](https://img.shields.io/npm/v/@jupyterlab/git.svg)](https://www.npmjs.com/package/@jupyterlab/git) [![Version](https://img.shields.io/pypi/v/jupyterlab-git.svg)](https://pypi.org/project/jupyterlab-git/) [![Downloads](https://img.shields.io/npm/dm/@jupyterlab/git.svg)](https://www.npmjs.com/package/@jupyterlab/git) [![Version](https://img.shields.io/conda/vn/conda-forge/jupyterlab-git.svg)](https://anaconda.org/conda-forge/jupyterlab-git) [![Downloads](https://img.shields.io/conda/dn/conda-forge/jupyterlab-git.svg)](https://anaconda.org/conda-forge/jupyterlab-git)<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->\n[![All Contributors](https://img.shields.io/badge/all_contributors-30-orange.svg?style=flat-square)](#contributors-)\n\n<!-- ALL-CONTRIBUTORS-BADGE:END -->\n\nA JupyterLab extension for version control using Git\n\n![ui_glow_up](https://raw.githubusercontent.com/jupyterlab/jupyterlab-git/main/docs/figs/preview.gif)\n\nTo see the extension in action, open the example notebook included in the Binder [demo](https://mybinder.org/v2/gh/jupyterlab/jupyterlab-git/main?urlpath=lab/tree/examples/demo.ipynb).\n\n## Requirements\n\n- JupyterLab >= 4.0 ([older version] available for 2.x)\n- Git (version `>=2.x`)\n\nFor older versions of JupyterLab, go to:\n\n- [3.x branch](https://github.com/jupyterlab/jupyterlab-git/tree/jlab-3)\n- [2.x branch](https://github.com/jupyterlab/jupyterlab-git/tree/jlab-2)\n\n## Usage\n\n- Open the Git extension from the _Git_ tab on the left panel\n- [Set up authentication](#authentication-to-remote-repository-hosts)\n\n## Install\n\nTo install perform the following steps, with _pip_:\n\n```bash\npip install --upgrade \"jupyterlab<4\" jupyterlab-git\n```\n\nor with _conda_:\n\n```bash\nconda install -c conda-forge \"jupyterlab<4\" jupyterlab-git\n```\n\n## Uninstall\n\nTo remove the extension, execute:\n\n```bash\npip uninstall jupyterlab_git\n```\n\nor with _conda_:\n\n```bash\nconda remove jupyterlab-git\n```\n\n## Settings\n\n### Authentication to remote repository hosts\n\nIf you are seeing errors similar to `[E yyyy-mm-dd hh:mm:ss ServerApp] 500 POST /git/<clone|push|pull|status>` on the console which is running the JupyterLab server, you probably need to set up a credentials store for your local Git repository.\n\nThis extension tries to handle credentials for HTTP(S) connections (if you don't have set up a credential manager). But not for other SSH connections.\n\n> For Windows users, it is recommended to install [git for windows](https://gitforwindows.org/). It will automatically set up a credential manager.\n> In order to connect to a remote host, it is recommended to use SSH.\n\n#### HTTP(S) protocol\n\nThe extension can cache temporarily (by default for an hour) credentials. To use the caching, you will need to\ncheck the option _Save my login temporarily_ in the dialog asking your credentials.\n\n> You can set a longer cache timeout; see [Server Settings](#server-settings).\n\n> This is a new feature since v0.37.0\n\n#### SSH protocol\n\nHere are the steps to follow to set up SSH authentication (skip any that is already accomplished for your project):\n\n1. [Create a SSH key](https://docs.github.com/en/github/authenticating-to-github/connecting-to-github-with-ssh/generating-a-new-ssh-key-and-adding-it-to-the-ssh-agent)\n2. Register the public part of it to your Git server:\n   - [GitHub](https://docs.github.com/en/github/authenticating-to-github/connecting-to-github-with-ssh/adding-a-new-ssh-key-to-your-github-account)\n   - [GitLab](https://docs.gitlab.com/ee/ssh/index.html#add-an-ssh-key-to-your-gitlab-account)\n3. Optionally, if you have more than one key managed by your ssh agent: [Create a config file for the ssh-agent](https://stackoverflow.com/a/21938804)\n4. Tell your local Git repository to [connect to remote via ssh](https://docs.github.com/en/get-started/getting-started-with-git/managing-remote-repositories#switching-remote-urls-from-https-to-ssh)\n\nYou should now be able to pull and push committed changes to and from your remote repository using the respective buttons on the top of the extension's panel.\n\n### UI Settings\n\nOnce installed, extension behavior can be modified via the following settings which can be set in JupyterLab's advanced settings editor:\n\n- **blockWhileCommandExecutes**: suspend JupyterLab user interaction until Git commands (e.g., `commit`, `pull`, `reset`, `revert`) finish executing. Setting this to `true` helps mitigate potential race conditions leading to data loss, conflicts, and a broken Git history. Unless running a slow network, UI suspension should not interfere with standard workflows. Setting this to `false` allows for actions to trigger multiple concurrent Git actions.\n- **cancelPullMergeConflict**: cancel pulling changes from a remote repository if there exists a merge conflict. If set to `true`, when fetching and integrating changes from a remote repository, a conflicting merge is canceled and the working tree left untouched.\n- **commitAndPush**: Whether to trigger or not a push for each commit; default is `false`.\n- **disableBranchWithChanges**: disable all branch operations, such as creating a new branch or switching to a different branch, when there are changed/staged files. When set to `true`, this setting guards against overwriting and/or losing uncommitted changes.\n- **displayStatus**: display Git extension status updates in the JupyterLab status bar. If `true`, the extension displays status updates in the JupyterLab status bar, such as when pulling and pushing changes, switching branches, and polling for changes. Depending on the level of extension activity, some users may find the status updates distracting. In which case, setting this to `false` should reduce visual noise.\n- **doubleClickDiff**: double click a file in the Git extension panel to open a diff of the file instead of opening the file for editing.\n- **historyCount**: number of commits shown in the history log, beginning with the most recent. Displaying a larger number of commits can lead to performance degradation, so use caution when modifying this setting.\n- **promptUserIdentity**: Whether to prompt for user name and email on every commit.\n- **refreshIfHidden**: whether to refresh even if the Git tab is hidden; default to `false` (i.e. refresh is turned off if the Git tab is hidden).\n- **refreshInterval**: number of milliseconds between polling the file system for changes. In order to ensure that the UI correctly displays the current repository status, the extension must poll the file system for changes. Longer polling times increase the likelihood that the UI does not reflect the current status; however, longer polling times also incur less performance overhead.\n- **simpleStaging**: enable a simplified concept of staging. When this setting is `true`, all files with changes are automatically staged. When we develop in JupyterLab, we often only care about what files have changed (in the broadest sense) and don't need to distinguish between \"tracked\" and \"untracked\" files. Accordingly, this setting allows us to simplify the visual presentation of changes, which is especially useful for those less acquainted with Git.\n\n### Server Settings\n\n- `JupyterLabGit.actions.post_init`: Set post _git init_ actions.\n  It is possible to provide a list of commands to be executed in a folder after it is initialized as Git repository.\n- `JupyterLabGit.credential_helper`: Git credential helper to set to cache the credentials.\n  The default value is `cache --timeout=3600` to cache the credentials for an hour. If you want to cache them for 10 hours, set `cache --timeout=36000`.\n- `JupyterLabGit.excluded_paths`: Set path patterns to exclude from this extension. You can use wildcard and interrogation mark for respectively everything or any single character in the pattern.\n- `JupyterLabGit.git_command_timeout_s`: Set the timeout for git operations. Defaults to 20 seconds.\n<details>\n<summary><b>How to set server settings?</b></summary>\n\nIn `$HOME/.jupyter/jupyter_notebook_config.py` (on Windows `%USERPROFILE%/.jupyter/jupyter_notebook_config.py`):\n\n```python\nc.JupyterLabGit.actions = {\"post_init\": [\"touch dummy_init.dat\"]}\nc.JupyterLabGit.credential_helper = 'cache --timeout=3600'\n```\n\nOr equivalently in `$HOME/.jupyter/jupyter_notebook_config.json` (on Windows `%USERPROFILE%/.jupyter/jupyter_notebook_config.json`):\n\n```json\n{\n  \"JupyterLabGit\": {\n    \"actions\": {\n      \"post_init\": [\"touch dummy_init.dat\"]\n    },\n    \"credential_helper\": \"cache --timeout=3600\"\n  }\n}\n```\n\n</details>\n\n## Troubleshoot\n\nIf you are seeing the frontend extension, but it is not working, check\nthat the server extension is enabled:\n\n```bash\njupyter server extension list\n```\n\nIf the server extension is installed and enabled, but you are not seeing\nthe frontend extension, check the frontend extension is installed:\n\n```bash\njupyter labextension list\n```\n\nIf they do not match or one is missing, please [reinstall the package](README.md#Install).\n\n<details><summary>the Git panel does not recognize that you are in a Git repository.</summary>\n\nPossible fixes:\n\n- Be sure to be in a Git repository in the filebrowser tab\n\n- Check the server log. If you see a warning with a 404 code similar to:\n  `[W 00:27:41.800 LabApp] 404 GET /git/settings?version=0.20.0`\n\n  Explicitly enable the server extension by running:\n\n  ```bash\n  jupyter server extension enable --py jupyterlab_git\n  ```\n\n- If you are using JupyterHub or some other technologies requiring an initialization script which includes the jupyterlab-git extension, be sure to install both the frontend and the server extension **before** launching JupyterLab.\n</details>\n\n<details>\n<summary>the Git panel is not visible.</summary>\n\nPossible fixes:\n\n- Check that the JupyterLab extension is installed:\n\n      ```bash\n      jupyter labextension list\n      ```\n\n      If you don't see `@jupyterlab/git v... enabled OK` in the list, explicitly install the jupyter labextension by running:\n\n      ```bash\n      jupyter labextension install @jupyterlab/git\n      ```\n\n      If you see `@jupyterlab/git` under `Uninstalled core extensions: `, your installation may have been corrupted. You can run `jupyter lab clean --all` and\n      reinstall all your extensions.\n\n</details>\n\n## Contributing\n\nIf you would like to contribute to the project, please read our [contributor documentation](https://github.com/jupyterlab/jupyterlab/blob/main/CONTRIBUTING.md).\n\nJupyterLab follows the official [Jupyter Code of Conduct](https://github.com/jupyter/governance/blob/main/conduct/code_of_conduct.md).\n\n### Development install\n\nNote: You will need NodeJS to build the extension package.\n\nThe `jlpm` command is JupyterLab's pinned version of\n[yarn](https://yarnpkg.com/) that is installed with JupyterLab. You may use\n`yarn` or `npm` in lieu of `jlpm` below.\n\n```bash\n# Clone the repo to your local environment\ngit clone https://github.com/jupyterlab/jupyterlab-git.git\n# Change directory to the jupyterlab-git directory\ncd jupyterlab-git\n# Install package in development mode\npip install -e \".[dev,test]\"\npre-commit install\n# Link your development version of the extension with JupyterLab\njupyter labextension develop . --overwrite\n# Server extension must be manually installed in develop mode\njupyter server extension enable jupyterlab_git\n# Rebuild extension Typescript source after making changes\njlpm run build\n```\n\nYou can watch the source directory and run JupyterLab at the same time in different terminals to watch for changes in the extension's source and automatically rebuild the extension.\n\n```bash\n# Watch the source directory in one terminal, automatically rebuilding when needed\njlpm run watch\n# Run JupyterLab in another terminal\njupyter lab\n```\n\nWith the watch command running, every saved change will immediately be built locally and available in your running JupyterLab. Refresh JupyterLab to load the change in your browser (you may need to wait several seconds for the extension to be rebuilt).\n\nBy default, the `jlpm run build` command generates the source maps for this extension to make it easier to debug using the browser dev tools. To also generate source maps for the JupyterLab core extensions, you can run the following command:\n\n```bash\njupyter lab build --minimize=False\n```\n\n### Development uninstall\n\n```bash\n# Server extension must be manually disabled in develop mode\njupyter server extension disable jupyterlab_git\npip uninstall jupyterlab_git\n```\n\nIn development mode, you will also need to remove the symlink created by `jupyter labextension develop`\ncommand. To find its location, you can run `jupyter labextension list` to figure out where the `labextensions`\nfolder is located. Then you can remove the symlink named `@jupyterlab/git` within that folder.\n\n### Testing the extension\n\n#### Server tests\n\nThis extension is using [Pytest](https://docs.pytest.org/) for Python code testing.\n\nInstall test dependencies (needed only once):\n\n```sh\npip install -e \".[test]\"\n# Each time you install the Python package, you need to restore the front-end extension link\njupyter labextension develop . --overwrite\n```\n\nTo execute them, run:\n\n```sh\npytest -vv -r ap --cov jupyterlab_git\n```\n\n#### Frontend tests\n\nThis extension is using [Jest](https://jestjs.io/) for JavaScript code testing.\n\nTo execute them, execute:\n\n```sh\njlpm\njlpm test\n```\n\n#### Integration tests\n\nThis extension uses [Playwright](https://playwright.dev/docs/intro) for the integration tests (aka user level tests).\nMore precisely, the JupyterLab helper [Galata](https://github.com/jupyterlab/jupyterlab/tree/master/galata) is used to handle testing the extension in JupyterLab.\n\nMore information are provided within the [ui-tests](./ui-tests/README.md) README.\n\n### Packaging the extension\n\nSee [RELEASE](RELEASE.md)\n\n## Contributors \u2728\n\nThe Jupyter Git extension is part of [Project Jupyter](http://jupyter.org/) and is developed by an open community of contributors. To see who has been active recently, please look at the [\"Contributors\"](https://github.com/jupyterlab/jupyterlab-git/graphs/contributors) tab. Below we list the people and entities who contributed in different ways to the project ([emoji key](https://allcontributors.org/docs/en/emoji-key)):\n\n<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n<!-- prettier-ignore-start -->\n<!-- markdownlint-disable -->\n<table>\n  <tbody>\n    <tr>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://amazon.com/aws\"><img src=\"https://avatars3.githubusercontent.com/u/2232217?v=4?s=100\" width=\"100px;\" alt=\"Amazon Web Services\"/><br /><sub><b>Amazon Web Services</b></sub></a><br /><a href=\"#financial-aws\" title=\"\">\ud83e\udd1d</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/ashutoshbondre\"><img src=\"https://avatars0.githubusercontent.com/u/13174154?v=4?s=100\" width=\"100px;\" alt=\"Ashutosh Bondre\"/><br /><sub><b>Ashutosh Bondre</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=ashutoshbondre\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aashutoshbondre\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/stdlib-js/stdlib\"><img src=\"https://avatars0.githubusercontent.com/u/2643044?v=4?s=100\" width=\"100px;\" alt=\"Athan\"/><br /><sub><b>Athan</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=kgryte\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Akgryte\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"#projectManagement-kgryte\" title=\"Project Management\">\ud83d\udcc6</a> <a href=\"#design-kgryte\" title=\"Design\">\ud83c\udfa8</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://basokant.com\"><img src=\"https://avatars.githubusercontent.com/u/70033855?v=4?s=100\" width=\"100px;\" alt=\"Ben Asokanthan\"/><br /><sub><b>Ben Asokanthan</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=basokant\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/BoscoCHW\"><img src=\"https://avatars.githubusercontent.com/u/45115214?v=4?s=100\" width=\"100px;\" alt=\"Bosco Chan\"/><br /><sub><b>Bosco Chan</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=BoscoCHW\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/ellisonbg\"><img src=\"https://avatars3.githubusercontent.com/u/27600?v=4?s=100\" width=\"100px;\" alt=\"Brian E. Granger\"/><br /><sub><b>Brian E. Granger</b></sub></a><br /><a href=\"#projectManagement-ellisonbg\" title=\"Project Management\">\ud83d\udcc6</a> <a href=\"#design-ellisonbg\" title=\"Design\">\ud83c\udfa8</a> <a href=\"#ideas-ellisonbg\" title=\"Ideas, Planning, & Feedback\">\ud83e\udd14</a> <a href=\"#fundingFinding-ellisonbg\" title=\"Funding Finding\">\ud83d\udd0d</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/Damans227\"><img src=\"https://avatars.githubusercontent.com/u/61474540?v=4?s=100\" width=\"100px;\" alt=\"Daman Arora\"/><br /><sub><b>Daman Arora</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=Damans227\" title=\"Code\">\ud83d\udcbb</a></td>\n    </tr>\n    <tr>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://dquach.dev\"><img src=\"https://avatars.githubusercontent.com/u/6735818?v=4?s=100\" width=\"100px;\" alt=\"Dat Quach\"/><br /><sub><b>Dat Quach</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=quachtridat\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/fcollonval\"><img src=\"https://avatars1.githubusercontent.com/u/8435071?v=4?s=100\" width=\"100px;\" alt=\"Fr\u00e9d\u00e9ric Collonval\"/><br /><sub><b>Fr\u00e9d\u00e9ric Collonval</b></sub></a><br /><a href=\"#maintenance-fcollonval\" title=\"Maintenance\">\ud83d\udea7</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><img src=\"https://avatars1.githubusercontent.com/u/27518229?v=4?s=100\" width=\"100px;\" alt=\"Hana Zarea\"/><br /><sub><b>Hana Zarea</b></sub><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=hzarea\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Ahzarea\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"http://ianhi.github.io\"><img src=\"https://avatars0.githubusercontent.com/u/10111092?v=4?s=100\" width=\"100px;\" alt=\"Ian Hunt-Isaak\"/><br /><sub><b>Ian Hunt-Isaak</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=ianhi\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aianhi\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/jaipreet-s\"><img src=\"https://avatars1.githubusercontent.com/u/43826141?v=4?s=100\" width=\"100px;\" alt=\"Jaipreet Singh\"/><br /><sub><b>Jaipreet Singh</b></sub></a><br /><a href=\"#projectManagement-jaipreet-s\" title=\"Project Management\">\ud83d\udcc6</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Ajaipreet-s\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=jaipreet-s\" title=\"Code\">\ud83d\udcbb</a> <a href=\"#design-jaipreet-s\" title=\"Design\">\ud83c\udfa8</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/zzhangjii\"><img src=\"https://avatars3.githubusercontent.com/u/11495372?v=4?s=100\" width=\"100px;\" alt=\"Ji Zhang\"/><br /><sub><b>Ji Zhang</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=zzhangjii\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Azzhangjii\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/kentarolim10\"><img src=\"https://avatars.githubusercontent.com/u/61769040?v=4?s=100\" width=\"100px;\" alt=\"Kentaro Lim\"/><br /><sub><b>Kentaro Lim</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=kentarolim10\" title=\"Code\">\ud83d\udcbb</a></td>\n    </tr>\n    <tr>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"http://taletskiy.com\"><img src=\"https://avatars0.githubusercontent.com/u/8834829?v=4?s=100\" width=\"100px;\" alt=\"Konstantin Taletskiy\"/><br /><sub><b>Konstantin Taletskiy</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=ktaletsk\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aktaletsk\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://kostyafarber.github.io/\"><img src=\"https://avatars.githubusercontent.com/u/73378227?v=4?s=100\" width=\"100px;\" alt=\"Kostya Farber\"/><br /><sub><b>Kostya Farber</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=kostyafarber\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://www.lindaful.com\"><img src=\"https://avatars.githubusercontent.com/u/68607795?v=4?s=100\" width=\"100px;\" alt=\"Linda Ngoc Nguyen\"/><br /><sub><b>Linda Ngoc Nguyen</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=iflinda\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://fellowship.mlh.io/\"><img src=\"https://avatars.githubusercontent.com/u/65834464?s=200&v=4?s=100\" width=\"100px;\" alt=\"Major League Hacking\"/><br /><sub><b>Major League Hacking</b></sub></a><br /><a href=\"#financial-mlh\" title=\"\">\ud83e\udd1d</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://www.linkedin.com/in/max-klein-b514419\"><img src=\"https://avatars2.githubusercontent.com/u/2263641?v=4?s=100\" width=\"100px;\" alt=\"Max Klein\"/><br /><sub><b>Max Klein</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=telamonian\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Atelamonian\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"#projectManagement-telamonian\" title=\"Project Management\">\ud83d\udcc6</a> <a href=\"#design-telamonian\" title=\"Design\">\ud83c\udfa8</a> <a href=\"#infra-telamonian\" title=\"Infrastructure (Hosting, Build-Tools, etc)\">\ud83d\ude87</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://www.linkedin.com/in/michal-krassowski/\"><img src=\"https://avatars.githubusercontent.com/u/5832902?v=4?s=100\" width=\"100px;\" alt=\"Micha\u0142 Krassowski\"/><br /><sub><b>Micha\u0142 Krassowski</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=krassowski\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Akrassowski\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/issues?q=author%3Akrassowski\" title=\"Bug reports\">\ud83d\udc1b</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://navn.me\"><img src=\"https://avatars.githubusercontent.com/u/59669957?v=4?s=100\" width=\"100px;\" alt=\"Navinn Ravindaran\"/><br /><sub><b>Navinn Ravindaran</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=navn-r\" title=\"Code\">\ud83d\udcbb</a></td>\n    </tr>\n    <tr>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/neelamgehlot\"><img src=\"https://avatars2.githubusercontent.com/u/15882916?v=4?s=100\" width=\"100px;\" alt=\"Neelam Gehlot\"/><br /><sub><b>Neelam Gehlot</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=neelamgehlot\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Aneelamgehlot\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"http://noahstapp.com/\"><img src=\"https://avatars0.githubusercontent.com/u/30483654?v=4?s=100\" width=\"100px;\" alt=\"Noah Stapp\"/><br /><sub><b>Noah Stapp</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=NoahStapp\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3ANoahStapp\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://www.saulshanabrook.com/\"><img src=\"https://avatars1.githubusercontent.com/u/1186124?v=4?s=100\" width=\"100px;\" alt=\"Saul Shanabrook\"/><br /><sub><b>Saul Shanabrook</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=saulshanabrook\" title=\"Code\">\ud83d\udcbb</a> <a href=\"#projectManagement-saulshanabrook\" title=\"Project Management\">\ud83d\udcc6</a> <a href=\"https://github.com/jupyterlab/jupyterlab-git/pulls?q=is%3Apr+reviewed-by%3Asaulshanabrook\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"#infra-saulshanabrook\" title=\"Infrastructure (Hosting, Build-Tools, etc)\">\ud83d\ude87</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/shawnesquivel\"><img src=\"https://avatars.githubusercontent.com/u/94336773?v=4?s=100\" width=\"100px;\" alt=\"Shawn Esquivel\"/><br /><sub><b>Shawn Esquivel</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=shawnesquivel\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"http://sheezaaziz.com\"><img src=\"https://avatars.githubusercontent.com/u/47278108?v=4?s=100\" width=\"100px;\" alt=\"Sheeza Aziz\"/><br /><sub><b>Sheeza Aziz</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=sheezaaziz\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"http://sinakhalili.com\"><img src=\"https://avatars.githubusercontent.com/u/20732540?v=4?s=100\" width=\"100px;\" alt=\"Sina Khalili\"/><br /><sub><b>Sina Khalili</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=SinaKhalili\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://www.deshaw.com/\"><img src=\"https://avatars0.githubusercontent.com/u/2298205?v=4?s=100\" width=\"100px;\" alt=\"The D. E. Shaw Group\"/><br /><sub><b>The D. E. Shaw Group</b></sub></a><br /><a href=\"#financial-deshaw\" title=\"\">\ud83e\udd1d</a></td>\n    </tr>\n    <tr>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/ZeshanFayyaz\"><img src=\"https://avatars.githubusercontent.com/u/43391249?v=4?s=100\" width=\"100px;\" alt=\"Zeshan Fayyaz\"/><br /><sub><b>Zeshan Fayyaz</b></sub></a><br /><a href=\"https://github.com/jupyterlab/jupyterlab-git/commits?author=ZeshanFayyaz\" title=\"Code\">\ud83d\udcbb</a></td>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/jupytercalpoly\"><img src=\"https://avatars0.githubusercontent.com/u/19445175?v=4?s=100\" width=\"100px;\" alt=\"jupytercalpoly\"/><br /><sub><b>jupytercalpoly</b></sub></a><br /><a href=\"#financial-jupytercalpoly\" title=\"\">\ud83e\udd1d</a></td>\n    </tr>\n  </tbody>\n</table>\n\n<!-- markdownlint-restore -->\n<!-- prettier-ignore-end -->\n\n<!-- ALL-CONTRIBUTORS-LIST:END -->\n\nThis project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind are welcomed!\n\nTo add yourself, or someone else, to this list you can either [use the bot](https://allcontributors.org/docs/en/bot/usage) (`@all-contributors please add <username> for <contributions>`) or [the CLI](https://allcontributors.org/docs/en/cli/usage) (`jlpm all-contributors add <username> <contributions>`).\n\nIf you manually edit the `.all-contributorsrc` config file, run `yarn run contributors:generate`.\n",
    "bugtrack_url": null,
    "license": "BSD 3-Clause License  Copyright (c) 2020, Jupyter Development Team All rights reserved.  Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.  3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.",
    "summary": "A JupyterLab extension for version control using git",
    "version": "0.50.0",
    "project_urls": {
        "Bug Tracker": "https://github.com/jupyterlab/jupyterlab-git/issues",
        "Homepage": "https://github.com/jupyterlab/jupyterlab-git",
        "Repository": "https://github.com/jupyterlab/jupyterlab-git.git"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "bc7f550561bba8537ee804e5602d356d8f71effe3391316e4871e6d85ee0ff7a",
                "md5": "7e526b0f2fbbb4af7f27ec5555a8c71c",
                "sha256": "00e399c2f828acc86ef58f2098c4d9bb2c0b52d37791dd5a56773a133e0c3da5"
            },
            "downloads": -1,
            "filename": "jupyterlab_git-0.50.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "7e526b0f2fbbb4af7f27ec5555a8c71c",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 1154407,
            "upload_time": "2023-11-21T14:38:56",
            "upload_time_iso_8601": "2023-11-21T14:38:56.864272Z",
            "url": "https://files.pythonhosted.org/packages/bc/7f/550561bba8537ee804e5602d356d8f71effe3391316e4871e6d85ee0ff7a/jupyterlab_git-0.50.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "490075df0ae290fea477232fd8f53dd71720366b54d5546ca313671cef5dde78",
                "md5": "721b2880cb46d083fbb068deca9eac33",
                "sha256": "09859546d390134ebb918a965c2c3fe2605feafe327cf61615be7dd90b5bdfbb"
            },
            "downloads": -1,
            "filename": "jupyterlab_git-0.50.0.tar.gz",
            "has_sig": false,
            "md5_digest": "721b2880cb46d083fbb068deca9eac33",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 15247584,
            "upload_time": "2023-11-21T14:39:02",
            "upload_time_iso_8601": "2023-11-21T14:39:02.919488Z",
            "url": "https://files.pythonhosted.org/packages/49/00/75df0ae290fea477232fd8f53dd71720366b54d5546ca313671cef5dde78/jupyterlab_git-0.50.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-11-21 14:39:02",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "jupyterlab",
    "github_project": "jupyterlab-git",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "jupyterlab-git"
}
        
Elapsed time: 0.15291s