Skip to content
/ mt_tool Public

Generate OC/Swift files for project or module.

Notifications You must be signed in to change notification settings

lyleLH/mt_tool

Repository files navigation

MtTool

A Ruby gem for generating VIPER architecture modules for iOS projects. Supports both Swift and Objective-C.

Module File Generator

Features

  • Generate complete VIPER module structure
  • Support for both Swift and Objective-C
  • Customizable templates
  • Command-line interface
  • Detailed logging for debugging

Installation

Add this line to your application's Gemfile:

gem 'mt_tool'

And then execute:

$ bundle install

Or install it yourself as:

$ gem install mt_tool

Usage

Generating a VIPER Module

# Generate a VIPER module
mt_tool vmod -n ModuleName -a "Author Name" -p ./path/to/module

# Example
mt_tool vmod -n HomeScreen -a "Tom Liu" -p ./Modules

Command Options

  • -n, --name: Module name (required)
  • -a, --author: Author name (required)
  • -p, --path: Target path for generation (required)

Generated Structure

ModuleName/
├── ModuleNameEntity.swift
├── ModuleNameInteractor.swift
├── ModuleNamePresenter.swift
├── ModuleNameRouter.swift
└── ModuleNameViewController.swift

Development

After checking out the repo, run bundle install to install dependencies.

To run the test suite:

bundle exec rake test

To install this gem onto your local machine:

bundle exec rake install

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b feature/my-new-feature)
  3. Add tests for your changes
  4. Make your changes
  5. Run the tests (bundle exec rake test)
  6. Commit your changes (git commit -am 'Add some feature')
  7. Push to the branch (git push origin feature/my-new-feature)
  8. Create new Pull Request

License

The gem is available as open source under the terms of the MIT License.

Code of Conduct

Everyone interacting in the MtTool project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.

About

Generate OC/Swift files for project or module.

Resources

Stars

Watchers

Forks

Packages

No packages published