xyz_gen 0.45.0  xyz_gen: ^0.45.0 copied to clipboard
xyz_gen: ^0.45.0 copied to clipboard
This package is designed to help speed up your development journey by generating boilerplate code for your projects.
π½πΎπΏ Gen #
This package is designed to help speed up your development journey by generating boilerplate code for your projects.
It comes with a set of generators that can be used as-is, or modified to suit your needs. Some generators use templates to create files, while others use hard-coded logic to generate or modify existing files. These templates can be modified to suit your needs and can be found in the templates folder.
To create your own generators, fork this package from https://github.com/robmllze/xyz_gen and customize it as needed or use this package as a dependency in your own package.
Documentation #
π Documentation and video tutorials are coming soon. Feel free to contact me for more information.
Included Generators #
βοΈ generate_directives.dart #
A quick way to create missing import, export or part-of directives to your files.
βοΈ generate_exports.dart #
Looks through a folder for all Dart files and creates an exports file that includes them all, simplifying your project.
βοΈ generate_license_headers.dart #
Adds license headers to your files, helping to protect your work.
βοΈ generate_makeups.dart #
Generates Makeups for widgets, giving them extra styles or features with ease.
βοΈ generate_models.dart #
Creates model classes from class annotations, handling types better than `json_serializable``.
βοΈ generate_preps.dart #
Inserts helpful information like line numbers and file names to keep things organized.
βοΈ generate_type_utils.dart #
Generates some utils for annotated Enums.
βοΈ generate_screen.dart (π οΈ not ready for public use) #
Creates Screens for your app, including the boilerplate code needed to get them up and running. Feel free to contact me for more information.
βοΈ generate_screen_access.dart (π οΈ not ready for public use) #
Connects your Screens to the navigator. Feel free to contact me for more information.
βοΈ generate_bindings.dart (π οΈ not ready for public use) #
Generates code to connect your Screens to your app. Feel free to contact me for more information.
Getting Started #
Installation #
If you are only interested in using the existing generators, there's no need to include this package, but you'll need to include the annotations package by modifying your pubspec.yaml file:
dependencies:
  xyz_gen_annotations: any  # or the latest version
If you want to use the tools included in this package to create your own generators package, you can include it like so:
dependencies:
  xyz_gen: any # or the latest version
Next Steps #
1. Clone the Generator Scripts:
Navigate to your project directory by running cd your/project/path in your terminal. Then clone the generator scripts repository:
On macOS and Linux:
git clone https://github.com/robmllze/___generators.git && rm -rf ___generators/.git/
On Windows:
git clone https://github.com/robmllze/___generators.git && rmdir /s /q ___generators/.git/
This will clone the generator scripts into your project directory and remove the .git directory, effectively detaching it from version control so that you can modify it as needed.
2. Modify the Generators as Needed:
Once cloned, you can modify the generator scripts or templates according to your project requirements.
3. Run the Generator Scripts:
Execute any of the generator scripts by navigating to the cloned directory and running:
dart ___generators/generate_models.dart
Replace generate_models.dart with the specific generator you wish to run, for example, dart generate_exports.dart.
4. Enhance Workflow Efficiency:
Consider setting up keyboard shortcuts or single-click actions to quickly run the generators. For instance, in Visual Studio Code, you can configure tasks to execute the generators with ease. Learn more: https://code.visualstudio.com/docs/editor/tasks.
Contributing #
Contributions are welcome. Here are a few ways you can help:
- Report bugs and make feature requests.
- Add new features.
- Improve the existing code.
- Help with documentation and tutorials.
License #
This package is released under the MIT License.
Contact #
Author: Robert Mollentze
Email: robmllze@gmail.com