Most applications are designed for small businesses with small amounts of data. Therefore most applications will never have to scale (i.e. become the next Twitter), so a relational database is overkill. However, persisting by simply saving the image is slow and error-prone. This simple (one class) framework saves only your model. The idea is to use it as long as you can get away with, which may be forever!
This repository carries on the original work by Ramon Leon (@gnaritas), which started as this an enlightening blog post.
Metacello new
baseline: 'SimplePersistence';
repository: 'github://seandenigris/Simple-Persistence';
load.
- Subclass
SpFileDatabase
. - Your SpFileDatabase subclass should respond to class-side
#schema
with a collection of client classes (i.e. for which we will be handling persistence). For example:MyProjectDB class>>#schema ^ { QuQuote. "a domain class that is part of our project" LivingLibraryDB "the DB from another project (LivingLibraryDB sbclass), which we will take over and persist as part of our model." }.
- All client classes (i.e.
QuQuote
andLivingLibraryDB
above) must respond to#spData
with the data to be persisted. SpFileDatabase subclasses get this for free. Here's an example of a domain client class implementation:MyDomainClass class>>#spData ^ { self uniqueInstance. self tags }
- All client classes must respond to
#restoreFrom:
taking the data they gave us to persist as the argument. Note that this is not an API change for domain classes, but nowSpFileDatabase
subclasses use the same message (which they get for free), instead of#restoreRepositories:
. Here is an example for the domain class in the point above:MyDomainClass class>>#restoreFrom: aCollection uniqueInstance := aCollection first. tags := aCollection second.
- Living Library - see
LivingLibraryDB
- My People - see
MyPeopleDB
- Resources-Live - see
ResourcesLiveDB
- The Project Project - see
TheProjectProjectDB