Skip to main content

A utility for finding versions in Git repositories

Project description

Version Finder

Coverage Report Latest Release

Version Finder is a command-line utility for finding and comparing versions in Git repositories. It provides an easy way to manage and analyze version information across multiple branches and submodules. The tool also supports easier GUI and CLI for more powerful operations.

Features

  • Find versions across different branches and submodules in a Git repository
  • Handle Git submodules
  • Retrieve detailed commit information

Installation

You can install Version Finder in 3 ways:

From PyPI

# Install core library only:
pip install version-finder-git-based-verions
# Install core library with GUI:
pip install version-finder-git-based-verions[gui]
# Install core library with CLI:
pip install version-finder-git-based-verions[cli]
# Install core library with CLI and GUI:
pip install version-finder-git-based-verions[cli-gui]
# Install core library with CLI, GUI and testing tools:
pip install version-finder-git-based-verions[all]

Note: The installation name is not version_finder, but version-finder-git-based-verions. Worry Not! Usage name is version_finder.

From GitHub Release

Download the latest wheel file from the releases page and install with:

Install core library only:

pip install version_finder-*.whl

Install core library with CLI:

pip install version_finder-*.whl[cli]

Install core library with GUI:

pip install version_finder-*.whl[gui]

(Recomended) Install core library with CLI and GUI:

pip install version_finder-*.whl[cli+gui]

From Source

  1. Ensure you have Python 3.6 or higher installed on your system.

  2. Clone the repository:

    git clone https://github.com/LevyMatan/version_finder.git
    cd version_finder
    
  3. Install the package using pip:

    make install
    

    You will be prompted to use what will be installed, the option are:

    • Core Library only
    • Core Library and CLI
    • Core Library and GUI
    • All

    Please note that this installation does not inlude the requierments for development.

Usage

After installation, you can use the version_finder command-line tool.

Note: At the moment it is highly advised to have a separate clone of your repository to be used for version searching.

Here are some example commands:

version_finder -p /path/to/repo -b <branch> -c <commit>  # Find versions in specified repository
version_finder --gui                            # Run the GUI
version-finder --cli                            # Run the CLI
version_finder -v                               # Run with verbose output

# If already in the repository directory, one can ommit the path parameter
version_finder -b <branch> -c <commit> -s <submodule>

For a full list of options, run:

version_finder --help

Direct Interaction

You can invoke a simple version finder with:

version_finder -p /path/to/repo -b target_branch -c target_commit [-s submodule_path]

This will find the first version containing the target commit within the target branch.

CLI

The CLI will enable user to interact with the library in a more interactive way. The first step will be to select the repository to work on. After that, the user will be asked to select the branch to work on.

Now the user will given the option to choose a TASK to perform. Based on the task chosen, user will have to enter additional information. Tasks include:

  • Find the first version containing a specific commit
  • Find the first version containing a specific commit in a specific submodule
  • Show all commits between two versions
  • Show all commits between two versions in a specific submodule

GUI

Reveales the same functionality as the CLI, but with a GUI interface. It also provides instant feedback for parameter correctness and hints in the form of autocomplete.

Code Structure

The Version Finder utility is structured as follows:

  • version_finder/__main__.py: Contains the a gateway to the library and will preform a simple task or open CLI or GUI.
  • version_finder/core.py: Implements the VersionFinder class, which handles Git operations, branch handling, and version extraction.
  • version_finder/logger.py: Sets up logging for the application
  • version_finder/protocols.py: Defines protocol classes for type hinting
  • version_finder/__cli__.py: Defines the CLI interface for the application
  • version_finder/__gui__.py: Defines the GUI interface for the application
  • version_finder/__common__.py: Defines common utility functions for both CLI and GUI

Core Components

  1. VersionFinder class:

    • Manages Git repository operations
    • Handles submodules and branches
    • Performs version extraction and retrieves commit information
  2. CLI Interface:

    • Provides a command-line interface for interacting with the application
    • Provides an interactive interface for selecting branches
    • Executes version finding operations based on user input

Contributing

Contributions to Version Finder are welcome! Here are some ways you can contribute:

  1. Report bugs or request features by opening issues
  2. Submit pull requests with bug fixes or new features
  3. Improve documentation or add examples

When contributing code, please ensure that you:

  • Follow the existing code style and conventions
  • Write appropriate tests for new features or bug fixes
  • Update the documentation as necessary

To set up a development environment:

  1. Clone the repository
  2. Create a virtual environment: python -m venv venv
  3. Activate the virtual environment:
    • On Windows: venv\Scripts\activate
    • On Unix or MacOS: source venv/bin/activate
  4. Install the package in editable mode: make install-dev
  5. Run tests: make test
  6. flake8: make lint
  7. autopep8: make format
  8. coverage report: make coverage

Before submitting a pull request, please ensure that all tests pass and the code adheres to the project's coding standards.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

File details

Details for the file version_finder_git_based_versions_cli-2.1.1.tar.gz.

File metadata

File hashes

Hashes for version_finder_git_based_versions_cli-2.1.1.tar.gz
Algorithm Hash digest
SHA256 8584a8f739c5520e08f965ba7bbd86ec4e094b8fe9fa333c9f10c085316a77b2
MD5 0c6c52df05ca7c6b46301c570bd1dfd4
BLAKE2b-256 eb3ee914c248c3f9c802415096107e76dc03d6d8db5ef7e1a48d002fe3d19ca5

See more details on using hashes here.

File details

Details for the file version_finder_git_based_versions_cli-2.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for version_finder_git_based_versions_cli-2.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 616c736f1a76bdcf073aa03982e35248d85999e621eba6a6904babdc19b292d1
MD5 b97310ae08feb43baec9b21e5ba26219
BLAKE2b-256 e18ec0c736b7849a84def774029dae9fe10b67fb2fec226cb2971ee915f46a16

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page