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.
- Find versions across different branches and submodules in a Git repository
- Handle Git submodules
- Retrieve detailed commit information
You can install Version Finder in 3 ways:
# Install core library only:
pip install version-finder-git-based-verions
# Install core library with GUI:
pip install version-finder-git-based-verions-gui-app
# 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-gui-app
pip install version-finder-git-based-verions-cli
# 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
, butversion-finder-git-based-verions
. Worry Not! Usage name isversion_finder
.
Download the latest wheel file from the releases page. Make sure you download the wanted flavor (core/cli/gui). Install using pip:
pip install version_finder-*.whl
-
Ensure you have Python 3.6 or higher installed on your system.
-
Clone the repository:
git clone https://github.com/LevyMatan/version_finder.git cd version_finder
-
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.
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
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.
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
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.
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 theVersionFinder
class, which handles Git operations, branch handling, and version extraction.version_finder/logger.py
: Sets up logging for the applicationversion_finder/protocols.py
: Defines protocol classes for type hintingversion_finder/__cli__.py
: Defines the CLI interface for the applicationversion_finder/__gui__.py
: Defines the GUI interface for the applicationversion_finder/__common__.py
: Defines common utility functions for both CLI and GUI
-
VersionFinder
class:- Manages Git repository operations
- Handles submodules and branches
- Performs version extraction and retrieves commit information
-
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
Contributions to Version Finder are welcome! Here are some ways you can contribute:
- Report bugs or request features by opening issues
- Submit pull requests with bug fixes or new features
- 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:
- Clone the repository
- Create a virtual environment:
python -m venv venv
- Activate the virtual environment:
- On Windows:
venv\Scripts\activate
- On Unix or MacOS:
source venv/bin/activate
- On Windows:
- Install the package in editable mode:
make install-dev
- Run tests:
make test
- flake8:
make lint
- autopep8:
make format
- 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.
This project is licensed under the MIT License - see the LICENSE file for details.