Home

Awesome

<p align="center"> <img width="750" src="https://raw.githubusercontent.com/arturdev/Unrealm/assets/unrealm.png" alt="Unrealm Header Logo"> </p> <br><br> <p align="center"> <a href="https://developer.apple.com/swift/"> <img src="https://img.shields.io/badge/Swift-5.1-orange.svg?style=flat" alt="Swift 5.1"> </a> <a href="https://travis-ci.com/arturdev/Unrealm"> <img src="https://travis-ci.com/arturdev/Unrealm.svg?branch=master" alt="Build Status"> </a> <a href="https://cocoapods.org/pods/Unrealm"> <img src="https://img.shields.io/cocoapods/v/Unrealm.svg?style=flat" alt="Version"> </a> <img src="https://img.shields.io/badge/spm-v0.2.5-orange.svg?style=flat" alt="Platform"> <a href="https://cocoapods.org/pods/Unrealm"> <img src="https://img.shields.io/cocoapods/l/Unrealm.svg?style=flat" alt="License"> </a> <a href="https://cocoapods.org/pods/Unrealm"> <img src="https://img.shields.io/cocoapods/p/Unrealm.svg?style=flat" alt="Platform"> </a> <a href="https://github.com/realm/realm-cocoa/releases/tag/v10.15.1"> <img src="https://img.shields.io/badge/RealmCocoa-v10.15.1-green?style=flat" alt="Platform"> </a> </p> <br/> <p align="center"> Unrealm enables you to easily store Swift native <b>Classes</b>, <b>Structs</b> and <b>Enums</b> into <a href="https://github.com/realm/realm-cocoa">Realm <img width="18" src = "https://raw.githubusercontent.com/arturdev/Unrealm/assets/realmLogoSmall.png"></a>.<br/>Stop inheriting from <b>Object</b>! Go for Protocol-Oriented programming!<br> Made with ❤️ by <a href="https://github.com/matghazaryan">matghazaryan</a> </p> <br> <p align="center"> <img width="1024" src="https://raw.githubusercontent.com/arturdev/Unrealm/assets/preview.png"> </p> <br>

Features

Unrealm supports the following types:

Example Project

To run the example project, clone the repo, and run pod install from the Example directory first.<br> See also <a href="https://github.com/arturdev/Unrealm/blob/master/Example/Tests/Tests.swift">Unit Tests</a>.

Usage

All you have to do is

  1. Conform your Classes/Structs to Realmable protocol instead of inheriting from Object. Conform your Enums to RealmableEnum protocol.
  2. Register your Classes/Structs and Enums in AppDelegate's didFinishLaunchingWithOptions.
Realm.registerRealmables(ToDoItem.self)

That's it! Now you can store your Struct or Class object into Realm as usually you do with Objc Classes.

Pros and Cons

Pros 🎉

Cons 🍟

let realm = try! Realm()
var todoItem = realm.object(ofType: ToDoItem.self, forPrimaryKey: "1")
todoItem.text = "Modified text"
try! realm.write {
realm.add(todoItem, update: true) //<- force Realm to update the object
}

Installation

CocoaPods

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

pod 'Unrealm'

Swift Package Manager

You can also use Swift Package Manager to add Unrealm as a dependency to your project. In order to do so, use the following URL:

https://github.com/matghazaryan/Unrealm.git

You need to use "master" branch instead of SPM.

ToDos

Contribution

⭐️ If you like what you see, star us on GitHub.

Find a bug, a typo, or something that’s not documented well? We’d love for you to open an issue telling me what I can improve!

Contributions are welcome, and they are greatly appreciated!

Author

matghazaryan, matevos14@gmail.com

License

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