libSmalldb
v0.3
|
Point of Smalldb is to make application logic easier to specify. This means it must be easy to define state machines. There are three ways of defining a state machine:
Since transition implementations require some PHP code anyway, there is no way to remove assigned PHP class completely (at least not for now). However, in common case it is not practical to define state machine in PHP code. Easier way is to use graphical editors like yEd to create GraphML file describing the state machine.
To make state machine diagram easy to create using existing tools, it is possible to "include" a GraphML file into JSON file. The GraphML file is parsed and converted into internal structure which is equivalent to the structure of the JSON file, then both files are merged together. If some option is defined in both files, value from JSON file is used, so it is easy to overcome imperfections of used editor.
doc/examples/statemachine/
directory....
label
: Human readable name of the state.
color
: Color of the state in diagrams.
group
: Group to which state belongs. Used only in diagrams.
label
: Human readable name of the transition.
color
: Color of the arrow and its label in diagrams.
weight
: Weight of arrow in diagrams. Heavier arrows should be shorter.
pre_check_methods
: List of method names executed just before transition invocation. If : exception is thrown or false
returned, the transition will not be : invoked. Arguments: ref, transition name, args.
post_transition_methods
: List of method names invoked after successful transition. : Arguments: ref, transition name, args, return value.
Properties options are passed with no processing to DUF and other related libraries which uses such metadata. State machine itself does not use most of the properties.
is_pk
: These properties are used as primary key (FlupdoMachine).
column_encoding
: Property is encoded/decoded to/from specified format before it is : stored in/loaded from database (FlupdoMachine).