gitease


Namegitease JSON
Version 0.0.11 PyPI version JSON
download
home_page
SummaryA tool to simplfy git operations
upload_time2023-07-26 09:25:38
maintainerXetHub
docs_urlNone
authorYonatan Alexander
requires_python>=3.8.1,<4.0.0
licenseBSD-3-Clause
keywords ai llm openai developer-tools git nlp
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <p align="center">
   <img src="https://xethub.com/xdssio/gitease/raw/branch/main/docs/images/logo.png" alt="logo" width="400" />
</p>


# GitEase
[![Version](https://img.shields.io/pypi/v/gitease.svg?style=flat)](https://pypi.python.org/pypi/gitease/)
[![Python](https://img.shields.io/pypi/pyversions/gitease.svg?style=flat)](https://pypi.python.org/pypi/gitease/)
[![License](https://img.shields.io/badge/license-MIT-blue?style=flat)](https://xethub.com/xdssio/gitease/src/branch/main/LICENSE)
[![Downloads](https://img.shields.io/pypi/dm/gitease?style=flat)](https://pypi.python.org/pypi/gitease/)
[![Documentation Status](https://readthedocs.org/projects/gitease/badge/?version=latest)](https://gitease.readthedocs.io/en/latest/?badge=latest)


A tool to simplify git usage with sprinkles of AI magic.

Humans think in simpler terms than git operates in. This tool aims to bridge that gap by providing a simpler language to
do common git tasks. Plus an LLM can write your commit messages for you.

You can load recent information with `gs load`, save current changes with `gs save` and share them with `gs share`.    
Behind the scenes it's exactly what you would expect from git, but with a simpler interface.

## Install

* Get an [openai api key](https://platform.openai.com/account/api-keys)

```bash
$ export OPENAI_API_KEY=...
$ pip install gitease
```

* If OPENAI_API_KEY is not set, you will be prompted to enter a commit message manually.

## Usage

Within a repo, run:

```bash
$ ge --help

Commands:
  --help:  Show this message and exit.        
    save <message>: Add and commit files to git. Massage is generated if not provided         
    share <message>: Share to remote - Add, commit and push changes to git. Massage is generated if not provided
    load :  Pull recent updates from git
    message: Generate commit message from diff using AI.
    undo: Undo last git action - only works using AI
```
### Examples
```bash
$ ge save

> Entering new StuffDocumentsChain chain...


> Entering new LLMChain chain...
Prompt after formatting:
Write a concise summary of the following:
...
> Finished chain.

Your commit message is:
docs: Update documentation, configuration, and index files
This commit updates the documentation, configuration, and index files for the project, including Makefile,
conf.py, and index.rst. These changes provide information about the project, its features, and quickstart
instructions. Additionally, it updates the version of gitease from 0.0.5 to 0.0.6.

To confirm, press Enter.
Otherwise, write your own message:
Press CTRL+C to cancel
Response:
```

```bash
# Add and Commit all python files in src with the message "feat: Add new script"
ge save -a 'src/*.py' -m 'feat: Add new script'

# Add multiple files
ge save -a README.md -a gitease/cli.py

# Add and commits everything without prompting for validation
ge save -y

# Add the README.md file and commit with a generated message
ge share -a README.md -y

# Add and commit README.md file with "upload readme" message, merges to main, and deletes the original branch
ge share -a README.md -m "upload readme" --merge=main --delete

# Pull recent changes from git
ge load
```

```bash
$ ge undo

Welcome to GitEase
Last git action is: Update README and CLI files
A revert command is: git reset HEAD@{0}
Shell I run the command for you? [y/n]: 
Running: git reset HEAD@{0}
Unstaged changes after reset:
M       README.md
M       gitease/cli.py
```
            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "gitease",
    "maintainer": "XetHub",
    "docs_url": null,
    "requires_python": ">=3.8.1,<4.0.0",
    "maintainer_email": "contact@xethub.com",
    "keywords": "ai,llm,openai,developer-tools,git,nlp",
    "author": "Yonatan Alexander",
    "author_email": "yonatan@xethub.com",
    "download_url": "https://files.pythonhosted.org/packages/7b/6b/dfa8a1d1c703681ca557b7a90e33832bd3ae2038aecb01d640d045460347/gitease-0.0.11.tar.gz",
    "platform": null,
    "description": "<p align=\"center\">\n   <img src=\"https://xethub.com/xdssio/gitease/raw/branch/main/docs/images/logo.png\" alt=\"logo\" width=\"400\" />\n</p>\n\n\n# GitEase\n[![Version](https://img.shields.io/pypi/v/gitease.svg?style=flat)](https://pypi.python.org/pypi/gitease/)\n[![Python](https://img.shields.io/pypi/pyversions/gitease.svg?style=flat)](https://pypi.python.org/pypi/gitease/)\n[![License](https://img.shields.io/badge/license-MIT-blue?style=flat)](https://xethub.com/xdssio/gitease/src/branch/main/LICENSE)\n[![Downloads](https://img.shields.io/pypi/dm/gitease?style=flat)](https://pypi.python.org/pypi/gitease/)\n[![Documentation Status](https://readthedocs.org/projects/gitease/badge/?version=latest)](https://gitease.readthedocs.io/en/latest/?badge=latest)\n\n\nA tool to simplify git usage with sprinkles of AI magic.\n\nHumans think in simpler terms than git operates in. This tool aims to bridge that gap by providing a simpler language to\ndo common git tasks. Plus an LLM can write your commit messages for you.\n\nYou can load recent information with `gs load`, save current changes with `gs save` and share them with `gs share`.    \nBehind the scenes it's exactly what you would expect from git, but with a simpler interface.\n\n## Install\n\n* Get an [openai api key](https://platform.openai.com/account/api-keys)\n\n```bash\n$ export OPENAI_API_KEY=...\n$ pip install gitease\n```\n\n* If OPENAI_API_KEY is not set, you will be prompted to enter a commit message manually.\n\n## Usage\n\nWithin a repo, run:\n\n```bash\n$ ge --help\n\nCommands:\n  --help:  Show this message and exit.        \n    save <message>: Add and commit files to git. Massage is generated if not provided         \n    share <message>: Share to remote - Add, commit and push changes to git. Massage is generated if not provided\n    load :  Pull recent updates from git\n    message: Generate commit message from diff using AI.\n    undo: Undo last git action - only works using AI\n```\n### Examples\n```bash\n$ ge save\n\n> Entering new StuffDocumentsChain chain...\n\n\n> Entering new LLMChain chain...\nPrompt after formatting:\nWrite a concise summary of the following:\n...\n> Finished chain.\n\nYour commit message is:\ndocs: Update documentation, configuration, and index files\nThis commit updates the documentation, configuration, and index files for the project, including Makefile,\nconf.py, and index.rst. These changes provide information about the project, its features, and quickstart\ninstructions. Additionally, it updates the version of gitease from 0.0.5 to 0.0.6.\n\nTo confirm, press Enter.\nOtherwise, write your own message:\nPress CTRL+C to cancel\nResponse:\n```\n\n```bash\n# Add and Commit all python files in src with the message \"feat: Add new script\"\nge save -a 'src/*.py' -m 'feat: Add new script'\n\n# Add multiple files\nge save -a README.md -a gitease/cli.py\n\n# Add and commits everything without prompting for validation\nge save -y\n\n# Add the README.md file and commit with a generated message\nge share -a README.md -y\n\n# Add and commit README.md file with \"upload readme\" message, merges to main, and deletes the original branch\nge share -a README.md -m \"upload readme\" --merge=main --delete\n\n# Pull recent changes from git\nge load\n```\n\n```bash\n$ ge undo\n\nWelcome to GitEase\nLast git action is: Update README and CLI files\nA revert command is: git reset HEAD@{0}\nShell I run the command for you? [y/n]: \nRunning: git reset HEAD@{0}\nUnstaged changes after reset:\nM       README.md\nM       gitease/cli.py\n```",
    "bugtrack_url": null,
    "license": "BSD-3-Clause",
    "summary": "A tool to simplfy git operations",
    "version": "0.0.11",
    "project_urls": null,
    "split_keywords": [
        "ai",
        "llm",
        "openai",
        "developer-tools",
        "git",
        "nlp"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "00db79c975f299740a061e1485c52fee0d34dede08581eea7bf101ae1ce7ae20",
                "md5": "0533f87032954500785be3920048cae7",
                "sha256": "9ef4cfc0cdcdde1327aed1925d0bab8e9609efef37b59d07134b618b6fd5919d"
            },
            "downloads": -1,
            "filename": "gitease-0.0.11-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "0533f87032954500785be3920048cae7",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8.1,<4.0.0",
            "size": 9925,
            "upload_time": "2023-07-26T09:25:36",
            "upload_time_iso_8601": "2023-07-26T09:25:36.960981Z",
            "url": "https://files.pythonhosted.org/packages/00/db/79c975f299740a061e1485c52fee0d34dede08581eea7bf101ae1ce7ae20/gitease-0.0.11-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "7b6bdfa8a1d1c703681ca557b7a90e33832bd3ae2038aecb01d640d045460347",
                "md5": "2530d68a454eec5afd7fd880186c357c",
                "sha256": "36918f33eb3bb391c5de768d87af832355eeb3ac80fa377edbed0b7d3192eb11"
            },
            "downloads": -1,
            "filename": "gitease-0.0.11.tar.gz",
            "has_sig": false,
            "md5_digest": "2530d68a454eec5afd7fd880186c357c",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8.1,<4.0.0",
            "size": 9351,
            "upload_time": "2023-07-26T09:25:38",
            "upload_time_iso_8601": "2023-07-26T09:25:38.506201Z",
            "url": "https://files.pythonhosted.org/packages/7b/6b/dfa8a1d1c703681ca557b7a90e33832bd3ae2038aecb01d640d045460347/gitease-0.0.11.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-07-26 09:25:38",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "gitease"
}
        
Elapsed time: 0.11290s