Skip to content

MonkeyPatch supplies Types with the ability to store temporary replacement values that are persisted.

License

Notifications You must be signed in to change notification settings

maxfell/MonkeyPatch

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

[![CI Status](http://img.shields.io/travis/Max Fellmuth/MonkeyPatch.svg?style=flat)](https://travis-ci.org/Max Fellmuth/MonkeyPatch) Version License Platform

🙊💬 MonkeyPatch

Start iterating like a maniac!

MonkeyPatch allows you to temporarliy replace values in you project during runtime with an extremely minimal code surface.

pod "MonkeyPatch"

Whaaaat?

They say a line of code is better than a thousand words:

1️⃣ Let's suppose we have a String like the right one ("Richard Hendricks").

print("PiedPiper CEO: ", "Richard Hendricks")
// => "PiedPiper CEO: Richard Hendricks"

2️⃣ If we provie a MonkeyPatch key and no value has been set for it, everything works as before.

print("PiedPiper CEO: ", "Richard Hendricks".monkeyPatch("replacementCEO"))
// => "PiedPiper CEO: Richard Hendricks"

3️⃣ BUT! If we have provided a value for the "replacementCEO" key anywhere in the app, that value will be returned.

String.setMonkeyPatch("replacementCEO", "Jack Barker")

print("PiedPiper CEO: ", "Richard Hendricks".monkeyPatch("replacementCEO"))
// => "PiedPiper CEO: Jack Barker"

Why?

This technique allows you to temporarily change values during runtime. You could use this as a foundation for an internal settings screen to set staging urls, toggle unreleased features, tweak animation values, you name it! The values are automatically persisted for you across app launches in the NSUserDefaults.

The beauty of this approach is that you don't need to add a lot of spaggheti code and you can easily remove it after you are done with tweaking.

How?

MonkeyPatch takes advantage of Swift's protocols and protocol extensions. That means it just works out of the box!

Example

To run the example project, clone the repo, and run pod install from the Example directory first.

Requirements

Installation

MonkeyPatch is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod "MonkeyPatch"

Author

Max Fellmuth, [email protected]

License

MonkeyPatch is available under the MIT license. See the LICENSE file for more info.

About

MonkeyPatch supplies Types with the ability to store temporary replacement values that are persisted.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published