0.01
Low commit activity in last 3 years
No release in over a year
The ActiveFacts API is a Ruby DSL for managing constellations of elementary facts. Each fact is either existential (a value or an entity), characteristic (boolean) or binary relational (A rel B). Relational facts are consistently co-referenced, so you can traverse them efficiently in any direction. Each constellation maintains constraints over the fact population.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 1.10
>= 10
~> 3.3

Runtime

>= 0.1.1, ~> 0
~> 2, >= 2.0.4
 Project Readme

activefacts-api¶ ↑

The ActiveFacts API provides the fact-oriented information management API for the ActiveFacts project. It is a Ruby DSL for managing constellations of elementary facts. Each fact is either existential (a value or an entity), characteristic (boolean) or binary relational (A rel B). Relational facts are consistently co-referenced, so you can traverse them efficiently in any direction. Each constellation maintains constraints over the fact population.

Contrary to object-oriented and relational modeling, fact oriented models do not use the concept of attributes. Fact types which express one-to-one or many-to-one relationships are fully mutual relationships between independent objects, which play the respective roles in the fact relationship. In addition, all objects are intrinsically identified, not by an external object-id. A constellation can not contain more than one instance of an object having the same identification. Accordingly there is no ‘new’ or ‘delete’ operations, just ‘assert’ and ‘retract’. This prevents problems caused by having duplicate representations of the same object.

The constellation is a universal and liberating data structure.

INSTALL:¶ ↑

  • sudo gem install activefacts-api

Contributing to activefacts-api¶ ↑

  • Check out the latest master to make sure the feature hasn’t been implemented or the bug hasn’t been fixed yet

  • Check out the issue tracker to make sure someone already hasn’t requested it and/or contributed it

  • Fork the project

  • Start a feature/bugfix branch

  • Commit and push until you are happy with your contribution

  • Make sure to add tests for it. This is important so I don’t break it in a future version unintentionally.

  • Please try not to mess with the Rakefile, version, or history. If you want to have your own version, or is otherwise necessary, that is fine, but please isolate to its own commit so I can cherry-pick around it.

Copyright © 2008-2011 Clifford Heath. See LICENSE.txt for further details.