SkillAgentSearch skills...

ViperCode

A simple OS X App for generating VIPER modules's skeleton to use them in your Objective-C/Swift projects.

Install / Use

/learn @iSame7/ViperCode
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

<h3 align="center"> <img src="./header.png" width="500" /> <br /> </a> </h3>

ViperCode

============

Mac OS X License

A simple OS X App for generate VIPER modules's skeleton to use them in your Objective-C/Swift projects.

Get in contact with the developer on Twitter: @same7mabrouk

What is VIPER?

VIPER is an application of Clean Architecture to iOS apps. The word VIPER is a backronym for View, Interactor, Presenter, Entity, and Routing. Clean Architecture divides an app’s logical structure into distinct layers of responsibility. This makes it easier to isolate dependencies (e.g. your database) and to test the interactions at the boundaries between layers: <img src="./VIPER.components.png" height="335" />

  • Know more about VIPER through this post http://www.objc.io/issue-13/viper.html

Features

  • Generate new VIPER modules in Swift and Objective-C
  • Generate new VIPER modules's unit tests for Swift and Objective-C
  • Friendly UI ViperCode module generation UI is similar to Xcode UI.
  • Good bye Ruby gems No need to install Ruby gems, ViperCode is native OS X app.

VIPER files structure

.objc
+-- DataManager
|   +-- VIPERDataManager.h
|   +-- VIPERDataManager.m
+-- Interactor
|   +-- VIPERInteractor.h
|   +-- VIPERInteractor.m
+-- Presenter
|   +-- VIPERPresenter.h
|   +-- VIPERPresenter.m
+-- ViewController
|   +-- VIPERViewController.h
|   +-- VIPERViewController.m
+-- WireFrame
|   +-- VIPERWireFrame.h
|   +-- VIPERWireFrame.m
+-- Protocols
|   +-- VIPERProtocols.h
.objc tests
+-- Interactor
|   +-- VIPERInteractorTests.m
+-- Presenter
|   +-- VIPERPresenterTests.m
+-- ViewController
|   +-- VIPERViewControllerTests.m
+-- WireFrame
|   +-- VIPERWireFrameTests.m
.swift
+-- DataManager
|   +-- VIPERDataManager.swift
+-- Interactor
|   +-- VIPERInteractor.swift
+-- Presenter
|   +-- VIPERPresenter.swift
+-- ViewController
|   +-- VIPERViewController.swift
+-- WireFrame
|   +-- VIPERWireFrame.swift
+-- Protocols
|   +-- VIPERProtocols.swift
.swift tests
+-- Interactor
|   +-- VIPERInteractorTests.swift
+-- Presenter
|   +-- VIPERPresenterTests.swift
+-- ViewController
|   +-- VIPERViewTests.swift
+-- WireFrame
|   +-- VIPERWireFrameTests.swift

Installation

Just clone the Repo, then build it using xCode 7.2 or above on any Mac OS X 10.10 or above.

Usage

Generating new VIPER module

Please enter the VIPER module name and module path then click generate button.

And then the files structure will be automatically created. Don't forget to add this folder to your project dragging it into the XCode or Appcode inspector.

Generating new VIPER module's unit tests

Please check "Include unit tests" option then enter the VIPER module name and tests file path then click generate button.

Note:

  • Don't Forget to add dependencies used in the generated code (unit tests classes).

  • Dependencies List:

    • OCMock: For objects mocking and dependency Injection.

Screenshot of the ViperCode OS X app. <img src="./ViperCode-screenshot.png" />

To DO

  • Make ViperCode plugin in Xcode
  • Add more VIPER templates in Swift and Objective-C

Change Log

  • Version 0.1
    • Added Default template
    • Support module generation for Swift and Objective-C

Need help?

Please submit an issue on GitHub, or contact me directly at mabrouksameh@gmail.com

License

This project is licensed under the terms of the MIT license. See the LICENSE file.

Related Skills

View on GitHub
GitHub Stars222
CategoryDevelopment
Updated19d ago
Forks30

Languages

Objective-C

Security Score

100/100

Audited on Mar 15, 2026

No findings