Name | xnippy JSON |
Version |
0.1.3
JSON |
| download |
home_page | None |
Summary | A Python module for dynamic integration and management of extensible code snippets. |
upload_time | 2024-05-06 03:22:31 |
maintainer | None |
docs_url | None |
author | None |
requires_python | >=3.7 |
license | MIT |
keywords |
code snippets
dynamic loading
extensible
plugin
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Xnippy - Extendable Plugin Architecture with Snippets for Python
Welcome to `xnippy`, a robust framework designed to facilitate the integration of a plugin architecture into your projects. This system allows for the dynamic enhancement and customization of applications through plugins, enhancing project sustainability without expanding the core codebase. `Xnippy` is ideal for those looking to add features for specific use cases or develop community-driven extensions while maintaining backward compatibility and minimizing dependencies.
This initiative stems from the need to evolve project features without the overhead of managing growing dependencies, thereby reducing maintenance challenges and allowing developers to focus on stabilizing and enriching the main codebase.
## **Plugins**
- **Independence**: Plugins can function as standalone applications, useful for personal data analysis projects. For dynamic functionality extension, your project should specify integration specifications, which ensure seamless plugin adoption.
- **Example**: For a practical implementation, see [BrkRaw](https://github.com/brkraw/brkraw.git), which utilizes `xnippy` for enhanced plugin integration.
- **Documentation**: Learn more about setting up and configuring plugins in our [Plugin Documentation](examples/docs/PLUGIN.md).
## Features of Xnippy's Plugin Architecture
- **Snippets**: Unlike traditional plugin systems that require separate package installations, `xnippy` uses snippets, allowing for instant updates and modifications without restarting Python kernels. This approach saves significant development time and simplifies testing.
- **GitHub Integration**: `xnippy` leverages GitHub as a repository server, enabling real-time updates and collaboration without the need for repackaging and redistributing through channels like PyPi. This feature ensures that new functionalities are instantly available without the need for updating the main package.
- **Simplicity**: Our plugin architecture avoids the complexities of `setup.py`, `setup.cfg`, or `pyproject.toml` files, focusing instead on straightforward GitHub-based sharing and version control.
### **Presets** -- WIP
- **Functionality**: Presets simplify configuring plugins with multiple input arguments, ensuring consistent setups and facilitating hyperparameter testing in machine learning projects.
- **Documentation**: Detailed information is available in our [Preset Documentation](examples/docs/PRESET.md).
### **Specifications (Specs)** -- WIP
- **Purpose**: Tailored for data analysis projects, specifications help define and validate data types and structures, ensuring data integrity and facilitating detailed inspections and validations similar to systems like Pydantic.
- **Documentation**: Explore our [Specification Documentation](examples/docs/SPEC.md) for more details.
### **Recipes** -- WIP
- **Utility**: Recipes allow for the automation of data preprocessing and metadata remapping, streamlining the integration and manipulation of datasets.
- **Documentation**: Learn how to create and use recipes with our [Recipe Documentation](examples/docs/RECIPE.md).
## Getting Started
To begin integrating `xnippy` into your project, refer to our comprehensive [Project Configuration Guide](examples/docs/PROJECT_CONFIG.md).
## Documentation
For detailed documentation on each component of the `xnippy` system, please visit the following links:
- [Project Configuration](examples/docs/PROJECT_CONFIG.md)
- [Plugins](examples/docs/PLUGIN.md)
- [Presets](examples/docs/PRESET.md)
- [Specifications for Dataset](examples/docs/SPEC.md)
- [Recipes for Parsing and Remapping MetaData](examples/docs/RECIPE.md)
Explore these documents to fully understand how each module can be utilized and configured to enrich your project with our versatile plugin architecture.
## Contributing
Contributions are welcome! If you have suggestions or improvements, please fork the repository and submit a pull request.
## License
`xnippy` is open-source software, freely distributed under the MIT license.
Raw data
{
"_id": null,
"home_page": null,
"name": "xnippy",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": "SungHo Lee <shlee@unc.edu>",
"keywords": "code snippets, dynamic loading, extensible, plugin",
"author": null,
"author_email": "SungHo Lee <shlee@unc.edu>",
"download_url": "https://files.pythonhosted.org/packages/96/e4/1f701c9b9815baabdfc5295881c346119fd3dfe4552fa2d9a8dc9a4e6243/xnippy-0.1.3.tar.gz",
"platform": null,
"description": "# Xnippy - Extendable Plugin Architecture with Snippets for Python\n\nWelcome to `xnippy`, a robust framework designed to facilitate the integration of a plugin architecture into your projects. This system allows for the dynamic enhancement and customization of applications through plugins, enhancing project sustainability without expanding the core codebase. `Xnippy` is ideal for those looking to add features for specific use cases or develop community-driven extensions while maintaining backward compatibility and minimizing dependencies.\n\nThis initiative stems from the need to evolve project features without the overhead of managing growing dependencies, thereby reducing maintenance challenges and allowing developers to focus on stabilizing and enriching the main codebase.\n\n## **Plugins**\n- **Independence**: Plugins can function as standalone applications, useful for personal data analysis projects. For dynamic functionality extension, your project should specify integration specifications, which ensure seamless plugin adoption.\n- **Example**: For a practical implementation, see [BrkRaw](https://github.com/brkraw/brkraw.git), which utilizes `xnippy` for enhanced plugin integration.\n- **Documentation**: Learn more about setting up and configuring plugins in our [Plugin Documentation](examples/docs/PLUGIN.md).\n\n## Features of Xnippy's Plugin Architecture\n- **Snippets**: Unlike traditional plugin systems that require separate package installations, `xnippy` uses snippets, allowing for instant updates and modifications without restarting Python kernels. This approach saves significant development time and simplifies testing.\n- **GitHub Integration**: `xnippy` leverages GitHub as a repository server, enabling real-time updates and collaboration without the need for repackaging and redistributing through channels like PyPi. This feature ensures that new functionalities are instantly available without the need for updating the main package.\n- **Simplicity**: Our plugin architecture avoids the complexities of `setup.py`, `setup.cfg`, or `pyproject.toml` files, focusing instead on straightforward GitHub-based sharing and version control.\n\n### **Presets** -- WIP\n- **Functionality**: Presets simplify configuring plugins with multiple input arguments, ensuring consistent setups and facilitating hyperparameter testing in machine learning projects.\n- **Documentation**: Detailed information is available in our [Preset Documentation](examples/docs/PRESET.md).\n\n### **Specifications (Specs)** -- WIP\n- **Purpose**: Tailored for data analysis projects, specifications help define and validate data types and structures, ensuring data integrity and facilitating detailed inspections and validations similar to systems like Pydantic.\n- **Documentation**: Explore our [Specification Documentation](examples/docs/SPEC.md) for more details.\n\n### **Recipes** -- WIP\n- **Utility**: Recipes allow for the automation of data preprocessing and metadata remapping, streamlining the integration and manipulation of datasets.\n- **Documentation**: Learn how to create and use recipes with our [Recipe Documentation](examples/docs/RECIPE.md).\n\n## Getting Started\nTo begin integrating `xnippy` into your project, refer to our comprehensive [Project Configuration Guide](examples/docs/PROJECT_CONFIG.md).\n\n## Documentation\nFor detailed documentation on each component of the `xnippy` system, please visit the following links:\n- [Project Configuration](examples/docs/PROJECT_CONFIG.md)\n- [Plugins](examples/docs/PLUGIN.md)\n - [Presets](examples/docs/PRESET.md)\n - [Specifications for Dataset](examples/docs/SPEC.md)\n - [Recipes for Parsing and Remapping MetaData](examples/docs/RECIPE.md)\n\nExplore these documents to fully understand how each module can be utilized and configured to enrich your project with our versatile plugin architecture.\n\n## Contributing\nContributions are welcome! If you have suggestions or improvements, please fork the repository and submit a pull request.\n\n## License\n`xnippy` is open-source software, freely distributed under the MIT license.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A Python module for dynamic integration and management of extensible code snippets.",
"version": "0.1.3",
"project_urls": {
"Homepage": "https://xoani.github.io"
},
"split_keywords": [
"code snippets",
" dynamic loading",
" extensible",
" plugin"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "ac01ec9378523cd648cbcbe32d2e55ffc29c3e7210afa0448e5e0e257eb685a6",
"md5": "8bcda322c1bb7341749ad23021ad89d7",
"sha256": "4f426e36dd0b1cc677a247f80be038f17326e6e399ff9c07cacfab38be9b9d4a"
},
"downloads": -1,
"filename": "xnippy-0.1.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "8bcda322c1bb7341749ad23021ad89d7",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 30160,
"upload_time": "2024-05-06T03:22:29",
"upload_time_iso_8601": "2024-05-06T03:22:29.540263Z",
"url": "https://files.pythonhosted.org/packages/ac/01/ec9378523cd648cbcbe32d2e55ffc29c3e7210afa0448e5e0e257eb685a6/xnippy-0.1.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "96e41f701c9b9815baabdfc5295881c346119fd3dfe4552fa2d9a8dc9a4e6243",
"md5": "a171404119ed95c791884df076fec0c8",
"sha256": "f92aff7d4a0ae4888c183492160adc39a3a19198489eeccbf3189ed16e6dd8fd"
},
"downloads": -1,
"filename": "xnippy-0.1.3.tar.gz",
"has_sig": false,
"md5_digest": "a171404119ed95c791884df076fec0c8",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 28652,
"upload_time": "2024-05-06T03:22:31",
"upload_time_iso_8601": "2024-05-06T03:22:31.056181Z",
"url": "https://files.pythonhosted.org/packages/96/e4/1f701c9b9815baabdfc5295881c346119fd3dfe4552fa2d9a8dc9a4e6243/xnippy-0.1.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-05-06 03:22:31",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "xnippy"
}