Popularity
5.6
Stable
Activity
3.0
-
536
13
67

Programming language: Swift
License: MIT License
Tags: Database    
Latest version: v1.3.5

Unrealm alternatives and similar libraries

Based on the "Database" category.
Alternatively, view Unrealm alternatives based on common mentions on social networks and blogs.

Do you think we are missing an alternative of Unrealm or a related project?

Add another 'Database' Library

README

Unrealm enables you to easily store Swift native Classes, Structs and Enums into Realm .Stop inheriting from Object! Go for Protocol-Oriented programming! Made with โค๏ธ by arturdev

Features

Unrealm supports the following types:

  • [x] Swift Primitives
  • [x] Swift Structs
  • [x] Swift Classes
  • [x] Swift Enums
  • [x] Swift Arrays
  • [x] Swift Dictionaries
  • [x] Nested Classes/Structs
  • [x] Swift Optionals (String, Data, Date)
  • [x] Swift Optionals of primitives (Int, Float, Double, Bool)
  • [x] Swift Optionals of Realmables
  • [x] Swift Optionals of Arrays
  • [x] Swift Arrays of enums

Example Project

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

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. Swift Realm.registerRealmables(ToDoItem.self) Thats it! Now you can store your Struct or Class object into Realm as usualy you do with Objc Classes.

Pros and Cons

Pros ๐ŸŽ‰

  • Enables you to store Swift native types (Structs, Classes, Enums, Arrays, Dictionaries, etc...)
  • Getting rid of redundant inheriting from Object class
  • Getting rid of Realm crashes like "Object has been deleted or invalidated"
  • Getting rid of Realm crashes like "Realm accessed from incorrect thread"
  • Getting rid of boilerplate code such as @objc dynamic var. Use just var or let
  • Getting rid of boilerplate code such as RealmOptional<Int>. Use just Int?
  • Works perfect with Swift's Codable and optional types!

Cons ๐ŸŸ

  • Losing "Live Objects" feature. Which means when you modify an object got from Realm the other ones will not be updated automatically. So after modifying an object you should manually update it in realm. f.e.; Swift 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/arturdev/Unrealm.git

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

ToDos

  • Add more UnitTests
  • Create a sample project for Swift Package Manager when dependencies can be added to many targets in a simple project.

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

arturdev, [email protected]

License

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


*Note that all licence references and agreements mentioned in the Unrealm README section above are relevant to that project's source code only.