Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ruby/pstore
PStore implements a file based persistence mechanism based on a Hash.
https://github.com/ruby/pstore
ruby
Last synced: 1 day ago
JSON representation
PStore implements a file based persistence mechanism based on a Hash.
- Host: GitHub
- URL: https://github.com/ruby/pstore
- Owner: ruby
- License: other
- Created: 2019-08-06T03:30:41.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2025-01-13T22:47:41.000Z (12 days ago)
- Last Synced: 2025-01-17T16:06:13.998Z (9 days ago)
- Topics: ruby
- Language: Ruby
- Homepage:
- Size: 141 KB
- Stars: 74
- Watchers: 30
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
README
# Pstore
PStore implements a file based persistence mechanism based on a Hash. User
code can store hierarchies of Ruby objects (values) into the data store file
by name (keys). An object hierarchy may be just a single object. User code
may later read values back from the data store or even update data, as needed.The transactional behavior ensures that any changes succeed or fail together.
This can be used to ensure that the data store is not left in a transitory
state, where some values were updated but others were not.Behind the scenes, Ruby objects are stored to the data store file with
Marshal. That carries the usual limitations. Proc objects cannot be
marshalled, for example.## Installation
Add this line to your application's Gemfile:
```ruby
gem 'pstore'
```And then execute:
$ bundle
Or install it yourself as:
$ gem install pstore
## Usage
```ruby
require "pstore"# a mock wiki object...
class WikiPage
def initialize( page_name, author, contents )
@page_name = page_name
@revisions = Array.newadd_revision(author, contents)
endattr_reader :page_name
def add_revision( author, contents )
@revisions << { :created => Time.now,
:author => author,
:contents => contents }
enddef wiki_page_references
[@page_name] + @revisions.last[:contents].scan(/\b(?:[A-Z]+[a-z]+){2,}/)
end# ...
end# create a new page...
home_page = WikiPage.new( "HomePage", "James Edward Gray II",
"A page about the JoysOfDocumentation..." )# then we want to update page data and the index together, or not at all...
wiki = PStore.new("wiki_pages.pstore")
wiki.transaction do # begin transaction; do all of this or none of it
# store page...
wiki[home_page.page_name] = home_page
# ensure that an index has been created...
wiki[:wiki_index] ||= Array.new
# update wiki index...
wiki[:wiki_index].push(*home_page.wiki_page_references)
end # commit changes to wiki data store file### Some time later... ###
# read wiki data...
wiki.transaction(true) do # begin read-only transaction, no changes allowed
wiki.roots.each do |data_root_name|
p data_root_name
p wiki[data_root_name]
end
end
```## Development
After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/ruby/pstore.