Skip to content
/ AFSM Public

AFSM - Simple 'Finite State Machine in Java', built for Android.

License

Notifications You must be signed in to change notification settings

duke79/AFSM

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

AFSM

AFSM - Simple 'Finite State Machine in Java', built for Android.

Example:

FSM.addStates(new String[]{
                "Root","SecondState"
        });

new Transition("Root","","SecondState")
        .setAction(new Action() {
            @Override
            public void run(Bundle data) {
                // Do something while going from Root to SecondState
                // Control comes here only if isGo returns true.
            }
        }); // Condition is optional (unless there are more than one transitions from a single state)
        .setCondition(new Condition() {
            @Override
            public boolean isGo(Bundle data) {
                // Put a condition to make this transition 'unique' from "Root"
                boolean condition = ...
                return condition;
            }
        });
        
// Call transit to invoke a transition
// Which transitition happpens, depends upon the "current state" of FSM and "condition check" for the transition.
Bundle data = new Bundle();
data.putString("key1","data1");
FSM.transit(data);

Usage

  • Option 1: AAR

  • Option 2: JITPACK (recommended)

    Step 1. Add the JitPack repository to your build file Add it in your root build.gradle at the end of repositories:

      allprojects {
      		repositories {
      			...
      			maven { url 'https://jitpack.io' }
      		}
      	}
    

    Step 2. Add the dependency

    dependencies {
            compile 'com.github.duke79:AFSM:-SNAPSHOT'
    }
    

About

AFSM - Simple 'Finite State Machine in Java', built for Android.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages