-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: guillemdb <guillem@fragile.tech>
- Loading branch information
Showing
1 changed file
with
148 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,148 @@ | ||
# hydraclick | ||
Develop CLI tools with top-notch config management like a boss | ||
# Hydraclick | ||
|
||
Hydraclick is an open-source Python package that seamlessly integrates [Hydra](https://hydra.cc/) and [Click](https://click.palletsprojects.com/) to create production-grade command-line interfaces (CLIs). It leverages Hydra's powerful configuration management with Click's user-friendly CLI creation to provide a robust foundation for building complex CLI applications. | ||
|
||
## Features | ||
|
||
- **Configuration Management**: Utilize Hydra's dynamic configuration capabilities for flexible CLI options. | ||
- **Structured Logging**: Integrate with flogging for structured and efficient logging. | ||
- **Easy Decorators**: Simple decorators to convert functions into CLI commands. | ||
- **Extensible**: Easily extend and customize to fit your project's needs. | ||
- **Shell Completion**: Support for generating shell completion scripts. | ||
|
||
## Installation | ||
|
||
Install Hydraclick via pip: | ||
|
||
```bash | ||
pip install hydraclick | ||
``` | ||
|
||
## Getting Started | ||
|
||
### Basic Usage | ||
|
||
Define your function and decorate it with `@hydra_command` to create a CLI command. | ||
|
||
```python | ||
from omegaconf import DictConfig | ||
from hydraclick import hydra_command | ||
|
||
@hydra_command(config_path="config", config_name="my_config") | ||
def my_function(config: DictConfig): | ||
print(f"Running with config: {config.pretty()}") | ||
``` | ||
|
||
### Running the CLI | ||
|
||
After defining your function, you can run it from the command line: | ||
|
||
```bash | ||
python my_script.py --config-path path/to/config --config-name my_config | ||
``` | ||
|
||
### Example | ||
|
||
Here's a complete example of creating a CLI with Hydraclick: | ||
|
||
```python | ||
import sys | ||
from omegaconf import DictConfig | ||
from hydraclick import hydra_command | ||
|
||
@hydra_command(config_path="configs", config_name="app_config", run_mode="kwargs") | ||
def main(**kwargs): | ||
print(f"Running with config: {kwargs}") | ||
|
||
if __name__ == "__main__": | ||
main() | ||
``` | ||
|
||
|
||
## API Reference | ||
|
||
### `hydra_command` | ||
|
||
Decorator to create CLI commands. | ||
|
||
```python | ||
def hydra_command( | ||
config_path: str | Path | None = None, | ||
config_name: str | None = "config", | ||
version_base: str | None = None, | ||
run_mode: str = "config", | ||
preprocess_config: Callable[[DictConfig], DictConfig] | None = None, | ||
print_config: bool = True, | ||
resolve: bool = True, | ||
use_flogging: bool = True, | ||
**flogging_kwargs: Any, | ||
) -> Callable: | ||
``` | ||
|
||
## Configuration Options | ||
|
||
Hydraclick provides several configuration options to customize your CLI: | ||
|
||
- `config_path`: Path to the configuration directory. Passed to [`hydra.main()`](https://hydra.cc/docs/tutorials/basic/your_first_app/config_file/) | ||
- `config_name`: Name of the configuration file. Passed to [`hydra.main()`](https://hydra.cc/docs/tutorials/basic/your_first_app/config_file/) | ||
- `version_base`: Base version of the configuration. Passed to [`hydra.main()`](https://hydra.cc/docs/tutorials/basic/your_first_app/config_file/) | ||
- `run_mode`: Mode to run the function (`"config"` or `"kwargs"`). | ||
- `"config"`: Pass the configuration as a single `OmegaConf.DictCondig` object. | ||
- `"kwargs"`: Resolve the `OmegaConf.DictConfig` objet into a python `dict` and pass it as keyword arguments. | ||
- `preprocess_config`: Function to preprocess the configuration. It takes a `DictConfig` object and returns a `DictConfig` object. | ||
- `print_config`: Whether to print the configuration before execution. | ||
- `resolve`: Whether to resolve the configuration. | ||
- `use_flogging`: Whether to use flogging for structured logging. | ||
- `**flogging_kwargs`: Additional keyword arguments for flogging. | ||
|
||
## Logging with Flogging | ||
|
||
Hydraclick integrates with [flogging](https://github.com/FragileTech/flogging) for structured logging. | ||
To enable flogging, ensure it's installed: | ||
|
||
```bash | ||
pip install hydraclick[flogging] | ||
``` | ||
|
||
```bash | ||
pip install flogging | ||
``` | ||
|
||
If `flogging` is not available, Hydraclick will log a warning and disable structured logging. | ||
|
||
## Shell Completion | ||
|
||
Hydraclick supports generating shell completion scripts. Use the `--shell-completion` option | ||
to generate scripts for your preferred shell. | ||
|
||
```bash | ||
cli_app command --shell-completion install=bash > my_script_completion.sh | ||
source my_script_completion.sh | ||
``` | ||
|
||
## Contribution | ||
|
||
Contributions are welcome! Please follow these steps: | ||
|
||
1. Fork the repository. | ||
2. Create a new branch for your feature or bugfix. | ||
3. Commit your changes with clear messages. | ||
4. Submit a pull request detailing your changes. | ||
|
||
For major changes, please open an issue first to discuss your ideas. | ||
|
||
## License | ||
|
||
This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details. | ||
|
||
## Support | ||
|
||
If you encounter any issues or have questions, feel free to open an issue on the [GitHub repository](https://github.com/yourusername/hydraclick). | ||
|
||
## Acknowledgements | ||
|
||
- [Hydra](https://hydra.cc/) for powerful configuration management. | ||
- [Click](https://click.palletsprojects.com/) for creating beautiful CLIs. | ||
- [Flogging](https://github.com/FragileTech/flogging) for structured logging. | ||
|
||
|