From 0f4e6520a053cf34f32ce860217e14406a540f8d Mon Sep 17 00:00:00 2001 From: John Haugeland Date: Sun, 29 Oct 2017 15:56:21 -0700 Subject: [PATCH] tests passing again --- CHANGELOG.md | 1 + README.md | 104 ++++++++++++++++++++++++++++++++++------- build/jssm.es5.js | 2 +- src/js/jssm.js | 4 +- src/js/tests/cycles.js | 12 +++-- 5 files changed, 100 insertions(+), 23 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1795bf41..1f18c64e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,4 @@ +* [[`1adc251876`](https://github.com/StoneCypher/jssm/commit/1adc251876)] - More towards cycles. Also started on mixed-unicode arrows (John Haugeland) * [[`04c514f1d1`](https://github.com/StoneCypher/jssm/commit/04c514f1d1)] - Post-merge and mostly done (John Haugeland) * [[`80416ccdd5`](https://github.com/StoneCypher/jssm/commit/80416ccdd5)] - Merge branch 'master' of github.com:StoneCypher/jssm (John Haugeland) * [[`8ac6b35409`](https://github.com/StoneCypher/jssm/commit/8ac6b35409)] - State declarations (John Haugeland) diff --git a/README.md b/README.md index f1fdaf8a..6ad21a1d 100644 --- a/README.md +++ b/README.md @@ -29,14 +29,16 @@ Language test cases for Belorussian, English, German, Hebrew, Italian, Russian, + + +

+ ## TL;DR Specify finite state machines with a brief syntax. Run them; they're fast. Derive charts. Save and load states, and histories. Make machine factories to churn out dozens or thousands of instances. Impress friends and loved ones. Cure corns and callouses. -```javascript -const traffic_light = sm` - Red 'Proceed' -> Green 'Proceed' -> Yellow 'Proceed' -> Red; -`; +```fsl +Red 'Proceed' -> Green 'Proceed' -> Yellow 'Proceed' -> Red; ``` This will produce the following FSM (graphed with [jssm-viz](https://github.com/StoneCypher/jssm-viz)): @@ -55,6 +57,10 @@ You'll build an executable state machine. As usual, a valid question. + + +
+ ### Why state machines State machines are a method of making your software better able to prevent illegal states. Similar to type systems, SQL @@ -77,6 +83,10 @@ So, to look at the same traffic light as above, you'll notice some things. Along with other common sense things, a good state machine implementation can help eliminate large classes of error in software. State machines are often applied when the stakes on having things correct are high. + + +
+ ### Why this implementation Brevity. @@ -91,6 +101,8 @@ to produce state machines in otherwise comparatively tiny and easily read code. +

+ ## Quick Start > A state machine in `JSSM` is defined in one of two ways: through the DSL, or through a datastructure. @@ -98,6 +110,10 @@ to produce state machines in otherwise comparatively tiny and easily read code. So yeah, let's start by getting some terminology out of the way, and then we can go right back to that impenetrable sentence, so that it'll make sense. + + +
+ ### Quick Terminology Finite state machines have been around forever, are used by everyone, and are hugely important. As a result, the @@ -118,6 +134,10 @@ For this quick overview, we'll define six basic concepts: There's other stuff, of course, but these five are enough to wrap your head around `finite state machine`s. + + +
+ #### Basic concepts This is a trivial traffic light `FSM`, with three states, three transitions, and one action: @@ -196,6 +216,10 @@ visualizations in [jssm-viz](https://github.com/StoneCypher/jssm-viz) by way of Enough history lesson. On with the tooling. + + +
+ ### And now, that Quick Start we were talking about So let's put together a trivial four-state traffic light: the three colors, plus **Off**. This will give us an @@ -205,6 +229,10 @@ At any time, you can take the code and put it into the [graph explorer](https://stonecypher.github.io/jssm-viz-demo/graph_explorer.html) for an opportunity to mess with the code as you see fit. + + +
+ #### 0: Lights always have an off state Our light will start in the **Off** `state`, with the ability to switch to the **Red** `state`. @@ -227,7 +255,7 @@ So far, our machine is simple: -

+
#### 1: Traffic lights have a three-color cycle @@ -251,7 +279,7 @@ Machine's still pretty simple: -

+
#### 2: Traffic lights can be shut down @@ -285,6 +313,10 @@ Machine's still not too bad: ![](https://raw.githubusercontent.com/StoneCypher/jssm/master/src/assets/traffic%20light%20quick%20start%20tutorial/Off%20To%20From%20RGY.png) + + +
+ ### Let's actually use the traffic light That's actually the bulk of the language. There are other little add-ons here and there, but, primarily you now know @@ -299,7 +331,7 @@ Let's load it and use it! 😀 -

+
### An introduction to machine design @@ -316,7 +348,8 @@ Remember, at any time, you can take the code and put it into the code as you see fit. -

+ +
#### 0: Empty machine @@ -330,7 +363,7 @@ EmptyWaiting 'Wait' -> EmptyWaiting; -

+
#### 1: Should be able to eject cards @@ -348,7 +381,7 @@ EjectCardAndReset -> EmptyWaiting; -

+
#### 2: Should be able to insert cards @@ -370,7 +403,7 @@ That will change as we go back to adding more nodes. `terminal node`s are usual -

+
#### 3: Should be able to cancel and recover the card @@ -391,7 +424,7 @@ EjectCardAndReset -> EmptyWaiting; -

+
#### 4: Can give the wrong PIN @@ -417,7 +450,7 @@ EjectCardAndReset -> EmptyWaiting; -

+
#### 5: Can give the correct PIN @@ -444,7 +477,7 @@ EjectCardAndReset -> EmptyWaiting; -

+
#### 6: Can check balance from main menu @@ -472,7 +505,7 @@ EjectCardAndReset -> EmptyWaiting; -

+
#### 7: Can deposit money from main menu @@ -548,7 +581,7 @@ EjectCardAndReset -> EmptyWaiting; -

+
#### 8: Can withdraw money from main menu @@ -629,6 +662,9 @@ As you can see, building up even very complex state machines is actually relativ amount of time. + +

+ ## Features ### DSL ### States @@ -651,8 +687,16 @@ amount of time. ### State history ### Automatic visualization + + +

+ ## How to think in state machines + + +

+ ## Example Machines ### Door lock ### Traffic lights @@ -675,14 +719,30 @@ amount of time. ### [BGP](https://upload.wikimedia.org/wikipedia/commons/thumb/a/a8/BGP_FSM.svg/549px-BGP_FSM.svg.png) ### [LibGCrypt FIPS mode FSM](https://www.gnupg.org/documentation/manuals/gcrypt/fips-fsm.png) + + +

+ ## How to debug + + +

+ ## How to publish + + +

+ ## Notation Comparison ### Their notations, one by one ### Apples to Apples - Traffic Light + + +

+ ## Other state machines There are a lot of state machine impls for JS, many quite a bit more mature than this one. Here are some options: @@ -717,10 +777,18 @@ And some similar stuff: 1. [GraphViz](http://www.graphviz.org/) 1. [Viz.js](https://github.com/mdaines/viz.js/), which we use + + +


+ # Thanks JSSM and FSL have had a lot of help. + + +

+ ## Internationalization * [Mykhaylo Les](https://github.com/miles91) provided three translation test cases ([Ukrainian](https://github.com/StoneCypher/jssm/blob/master/src/js/tests/language_data/ukrainian.json), [Belarussian](https://github.com/StoneCypher/jssm/blob/master/src/js/tests/language_data/belarussian.json), and [Russian](https://github.com/StoneCypher/jssm/blob/master/src/js/tests/language_data/russian.json),) and the corresponding Traffic Light translations (also [Ukrainian](https://github.com/StoneCypher/fsl_traffic_light_ukrainian/blob/master/traffic%20light.fsl), [Belarussian](https://github.com/StoneCypher/fsl_traffic_light_belarussian/blob/master/traffic_light.fsl), and [Russian](https://github.com/StoneCypher/fsl_traffic_light_russian/blob/master/traffic%20light.fsl).) @@ -738,6 +806,10 @@ If you'd like to help, it's straightforward. 1. Easy mode: open a PR with [this file](https://github.com/StoneCypher/jssm/blob/master/src/js/tests/language_data/english.json) translated into your language 1. Extra mile: create a new repo containing [this file](https://github.com/StoneCypher/fsl_traffic_light/blob/master/traffic_light.fsl) translated + + +

+ ## Code and Language [Forest Belton](https://github.com/forestbelton) has provided guidance, bugfixes, parser and language commentary. diff --git a/build/jssm.es5.js b/build/jssm.es5.js index b60ab8a1..f1d3096d 100644 --- a/build/jssm.es5.js +++ b/build/jssm.es5.js @@ -991,4 +991,4 @@ exports.weighted_rand_select = _jssmUtil.weighted_rand_select; exports.histograph = _jssmUtil.histograph; exports.weighted_sample_select = _jssmUtil.weighted_sample_select; exports.weighted_histo_key = _jssmUtil.weighted_histo_key; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/js/jssm.js"],"names":["reduce_to_639","require","reduce","parse","version","arrow_direction","arrow","String","Error","arrow_left_kind","arrow_right_kind","makeTransition","this_se","from","to","isRight","wasList","wasIndex","kind","edge","forced_only","main_path","undefined","action","probability","compile_rule_transition_step","acc","next_se","edges","uFrom","Array","isArray","uTo","map","f","t","right","push","left","new_acc","concat","se","compile_rule_handle_transition","rule","compile_rule_handler","key","agg_as","val","value","name","state","declarations","tautologies","includes","JSON","stringify","compile","tree","results","graph_layout","transition","start_states","end_states","state_declaration","fsl_version","machine_author","machine_comment","machine_contributor","machine_definition","machine_language","machine_license","machine_name","machine_reference","machine_version","tr","assembled_transitions","result_cfg","length","transitions","oneOnlyKeys","oneOnlyKey","multiKey","make","plan","transfer_state_properties","state_decl","d","node_shape","node_color","Machine","complete","_state","_states","Map","_state_declarations","_edges","_edge_map","_named_transitions","_actions","_reverse_actions","_reverse_action_targets","_machine_author","_machine_comment","_machine_contributor","_machine_definition","_machine_language","_machine_license","_machine_name","_machine_version","_raw_state_declaration","_fsl_version","_graph_layout","has","set","cursor_from","get","_new_state","cursor_to","thisEdgeId","from_mapping","actionMap","rActionMap","state_config","whichState","state_is_terminal","state_is_complete","state_is_final","which","internal_state_impl_version","actions","edge_map","named_transitions","reverse_actions","states","keys","emg","id","get_transition_by_state_names","entrances","list_entrances","exits","list_exits","wstate","wstate_to","wtf","ws","lookup_transition_for","filter","Boolean","selected","probable_exits_for","n","state_was","probabilistic_transition","probabilistic_walk","ra_base","values","edgeId","o","filtered","some","x","is_unenterable","newData","valid_action","current_action_edge_for","newState","valid_transition","valid_force_transition","action_base","idx","current_action_for","_newData","transition_for","sm","template_strings","seq","weighted_rand_select","histograph","weighted_sample_select","weighted_histo_key"],"mappings":"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","file":"jssm.js","sourcesContent":["\n// whargarbl lots of these return arrays could/should be sets\n\n// @flow\n\nconst reduce_to_639 : Function = require('reduce-to-639-1').reduce;\n\n\n\n\n\nimport type {\n\n  JssmGenericState, JssmGenericConfig,\n  JssmTransition, JssmTransitionList, JssmTransitionRule,\n  JssmMachineInternalState,\n  JssmParseTree,\n  JssmStateDeclaration, JssmStateDeclarationRule,\n  JssmCompileSe, JssmCompileSeStart, JssmCompileRule,\n  JssmArrow, JssmArrowDirection, JssmArrowKind,\n  JssmLayout\n\n} from './jssm-types';\n\n\n\n\n\nimport { seq, weighted_rand_select, weighted_sample_select, histograph, weighted_histo_key } from './jssm-util.js';\n\nconst parse: Function = require('./jssm-dot.js').parse;  // eslint-disable-line flowtype/no-weak-types // todo whargarbl remove any\n\nconst version: null = null; // replaced from package.js in build\n\n\n\n\n\n/* eslint-disable complexity */\n\nfunction arrow_direction(arrow: JssmArrow): JssmArrowDirection {\n\n  switch ( String(arrow) ) {\n\n    case '->'   :      case '→'  :\n    case '=>'   :      case '⇒'  :\n    case '~>'   :      case '↛'  :\n      return 'right';\n\n    case '<-'   :      case '←'  :\n    case '<='   :      case '⇐'  :\n    case '<~'   :      case '↚'  :\n      return 'left';\n\n    case '<->'  :      case '↔'  :\n    case '<-=>' :      case '←⇒' :      case '←=>' :      case '<-⇒' :\n    case '<-~>' :      case '←↛' :      case '←~>' :      case '<-↛' :\n\n    case '<=>'  :      case '⇔'  :\n    case '<=->' :      case '⇐→' :      case '⇐->' :      case '<=→' :\n    case '<=~>' :      case '⇐↛' :      case '⇐~>' :      case '<=↛' :\n\n    case '<~>'  :      case '↮'  :\n    case '<~->' :      case '↚→' :      case '↚->' :      case '<~→' :\n    case '<~=>' :      case '↚⇒' :      case '↚=>' :      case '<~⇒' :\n      return 'both';\n\n    default:\n      throw new Error(`arrow_direction: unknown arrow type ${arrow}`);\n\n  }\n\n}\n\n/* eslint-enable complexity */\n\n\n\n\n\n/* eslint-disable complexity */\n\nfunction arrow_left_kind(arrow: JssmArrow): JssmArrowKind {\n\n  switch ( String(arrow) ) {\n\n    case '->' :    case '→' :\n    case '=>' :    case '⇒' :\n    case '~>' :    case '↛' :\n      return 'none';\n\n    case '<-':     case '←' :\n    case '<->':    case '↔' :\n    case '<-=>':   case '←⇒' :\n    case '<-~>':   case '←↛' :\n      return 'legal';\n\n    case '<=':     case '⇐' :\n    case '<=>':    case '⇔' :\n    case '<=->':   case '⇐→' :\n    case '<=~>':   case '⇐↛' :\n      return 'main';\n\n    case '<~':     case '↚' :\n    case '<~>':    case '↮' :\n    case '<~->':   case '↚→' :\n    case '<~=>':   case '↚⇒' :\n      return 'forced';\n\n    default:\n      throw new Error(`arrow_direction: unknown arrow type ${arrow}`);\n\n  }\n\n}\n\n/* eslint-enable complexity */\n\n\n\n\n\n/* eslint-disable complexity */\n\nfunction arrow_right_kind(arrow: JssmArrow): JssmArrowKind {\n\n  switch ( String(arrow) ) {\n\n    case '<-' :    case '←' :\n    case '<=' :    case '⇐' :\n    case '<~' :    case '↚' :\n      return 'none';\n\n    case '->' :    case '→' :\n    case '<->':    case '↔' :\n    case '<=->':   case '⇐→' :\n    case '<~->':   case '↚→' :\n      return 'legal';\n\n    case '=>' :    case '⇒' :\n    case '<=>':    case '⇔' :\n    case '<-=>':   case '←⇒' :\n    case '<~=>':   case '↚⇒' :\n      return 'main';\n\n    case '~>' :    case '↛' :\n    case '<~>':    case '↮' :\n    case '<-~>':   case '←↛' :\n    case '<=~>':   case '⇐↛' :\n      return 'forced';\n\n    default:\n      throw new Error(`arrow_direction: unknown arrow type ${arrow}`);\n\n  }\n\n}\n\n/* eslint-enable complexity */\n\n\n\n\n\nfunction makeTransition<mNT, mDT>(\n  this_se   : JssmCompileSe<mNT>,\n  from      : mNT,\n  to        : mNT,\n  isRight   : boolean,\n  wasList?  : Array<mNT>,\n  wasIndex? : number\n) : JssmTransition<mNT, mDT> {\n\n  const kind : JssmArrowKind            = isRight? arrow_right_kind(this_se.kind) : arrow_left_kind(this_se.kind),\n        edge : JssmTransition<mNT, mDT> = {\n          from,\n          to,\n          kind,\n          forced_only : kind === 'forced',\n          main_path   : kind === 'main'\n        };\n\n  if ((wasList !== undefined)  && (wasIndex === undefined)) { throw \"Must have an index if transition was in a list\"; }\n  if ((wasIndex !== undefined) && (wasList === undefined))  { throw \"Must be in a list if transition has an index\";   }\n/*\n  if (typeof edge.to === 'object') {\n\n    if (edge.to.key === 'cycle') {\n      if (wasList === undefined) { throw \"Must have a waslist if a to is type cycle\"; }\n      const nextIndex = wrapBy(wasIndex, edge.to.value, wasList.length);\n      edge.to = wasList[nextIndex];\n    }\n\n  }\n*/\n  const action      : string = isRight? 'r_action'      : 'l_action',\n        probability : string = isRight? 'r_probability' : 'l_probability';\n\n  if (this_se[action])      { edge.action      = this_se[action];      }\n  if (this_se[probability]) { edge.probability = this_se[probability]; }\n\n  return edge;\n\n}\n\n\n\n\n\nfunction compile_rule_transition_step<mNT, mDT>(\n             acc     : Array< JssmTransition<mNT, mDT> >,\n             from    : mNT,\n             to      : mNT,\n             this_se : JssmCompileSe<mNT>,\n             next_se : JssmCompileSe<mNT>\n         ) : Array< JssmTransition<mNT, mDT> > { // todo flow describe the parser representation of a transition step extension\n\n  const edges : Array< JssmTransition<mNT, mDT> > = [];\n\n  const uFrom : Array< mNT > = (Array.isArray(from)? from : [from]),\n        uTo   : Array< mNT > = (Array.isArray(to)?   to   : [to]  );\n\n  uFrom.map( (f: mNT) => {\n    uTo.map( (t: mNT) => {\n\n      const right: JssmTransition<mNT, mDT> = makeTransition(this_se, f, t, true);\n      if (right.kind !== 'none') { edges.push(right); }\n\n      const left: JssmTransition<mNT, mDT> = makeTransition(this_se, t, f, false);\n      if (left.kind !== 'none') { edges.push(left); }\n\n    });\n  });\n\n  const new_acc: Array< JssmTransition<mNT, mDT> > = acc.concat(edges);\n\n  if (next_se) {\n    return compile_rule_transition_step(new_acc, to, next_se.to, next_se, next_se.se);\n  } else {\n    return new_acc;\n  }\n\n}\n\n\n\nfunction compile_rule_handle_transition<mNT>(rule: JssmCompileSeStart<mNT>): mixed { // todo flow describe the parser representation of a transition\n  return compile_rule_transition_step([], rule.from, rule.se.to, rule.se, rule.se.se);\n}\n\n\n\nfunction compile_rule_handler<mNT>(rule: JssmCompileSeStart<mNT>): JssmCompileRule { // todo flow describe the output of the parser\n\n  if (rule.key === 'transition') {\n    return { agg_as: 'transition', val: compile_rule_handle_transition(rule) };\n  }\n\n  if (rule.key === 'machine_language') {\n    return { agg_as: 'machine_language', val: reduce_to_639(rule.value) };\n  }\n\n  if (rule.key === 'state_declaration') {\n    if (!rule.name) { throw new Error('State declarations must have a name'); }\n    return { agg_as: 'state_declaration', val: { state: rule.name, declarations: rule.value } };\n  }\n\n  const tautologies : Array<string> = [\n    'graph_layout', 'start_states', 'end_states', 'machine_name', 'machine_version',\n    'machine_comment', 'machine_author', 'machine_contributor', 'machine_definition',\n    'machine_reference', 'machine_license', 'fsl_version'\n  ];\n\n  if (tautologies.includes(rule.key)) {\n    return { agg_as: rule.key, val: rule.value };\n  }\n\n  throw new Error(`compile_rule_handler: Unknown rule: ${JSON.stringify(rule)}`);\n\n}\n\n\n\n\n\nfunction compile<mNT, mDT>(tree: JssmParseTree<mNT>): JssmGenericConfig<mNT, mDT> {  // todo flow describe the output of the parser\n\n  const results : {\n    graph_layout        : Array< JssmLayout >,\n    transition          : Array< JssmTransition<mNT, mDT> >,\n    start_states        : Array< mNT >,\n    end_states          : Array< mNT >,\n    state_declaration   : Array< mNT >,\n    fsl_version         : Array< string >,\n    machine_author      : Array< string >,\n    machine_comment     : Array< string >,\n    machine_contributor : Array< string >,\n    machine_definition  : Array< string >,\n    machine_language    : Array< string >,\n    machine_license     : Array< string >,\n    machine_name        : Array< string >,\n    machine_reference   : Array< string >,\n    machine_version     : Array< string > // semver\n  } = {\n    graph_layout        : [],\n    transition          : [],\n    start_states        : [],\n    end_states          : [],\n    state_declaration   : [],\n    fsl_version         : [],\n    machine_author      : [],\n    machine_comment     : [],\n    machine_contributor : [],\n    machine_definition  : [],\n    machine_language    : [],\n    machine_license     : [],\n    machine_name        : [],\n    machine_reference   : [],\n    machine_version     : []\n  };\n\n  tree.map( (tr : JssmCompileSeStart<mNT>) => {\n\n    const rule   : JssmCompileRule = compile_rule_handler(tr),\n          agg_as : string          = rule.agg_as,\n          val    : mixed           = rule.val;                  // todo better types\n\n    results[agg_as] = results[agg_as].concat(val);\n\n  });\n\n  const assembled_transitions : Array< JssmTransition<mNT, mDT> > = [].concat(... results['transition']);\n\n  const result_cfg : JssmGenericConfig<mNT, mDT> = {\n    start_states : results.start_states.length? results.start_states : [assembled_transitions[0].from],\n    transitions  : assembled_transitions\n  };\n\n  const oneOnlyKeys : Array<string> = [\n    'graph_layout', 'machine_name', 'machine_version', 'machine_comment', 'fsl_version', 'machine_license',\n    'machine_definition', 'machine_language'\n  ];\n\n  oneOnlyKeys.map( (oneOnlyKey : string) => {\n    if (results[oneOnlyKey].length > 1) {\n      throw new Error(`May only have one ${oneOnlyKey} statement maximum: ${JSON.stringify(results[oneOnlyKey])}`);\n    } else {\n      if (results[oneOnlyKey].length) {\n        result_cfg[oneOnlyKey] = results[oneOnlyKey][0];\n      }\n    }\n  });\n\n  ['machine_author', 'machine_contributor', 'machine_reference', 'state_declaration'].map( (multiKey : string) => {\n    if (results[multiKey].length) {\n      result_cfg[multiKey] = results[multiKey];\n    }\n  });\n\n  return result_cfg;\n\n}\n\n\n\n\n\nfunction make<mNT, mDT>(plan: string): JssmGenericConfig<mNT, mDT> {\n  return compile(parse(plan));\n}\n\n\n\n\n\nfunction transfer_state_properties<mNT>(state_decl: JssmStateDeclaration<mNT>): JssmStateDeclaration<mNT> {\n\n    state_decl.declarations.map( (d: JssmStateDeclarationRule) => {\n      switch (d.key) {\n\n        case 'node_shape' : state_decl.node_shape = d.value; break;\n        case 'node_color' : state_decl.node_color = d.value; break;\n\n        default: throw new Error(`Unknown state property: '${JSON.stringify(d)}'`);\n\n      }\n    });\n\n    return state_decl;\n\n}\n\n\n\n\n\nclass Machine<mNT, mDT> {\n\n\n  _state                  : mNT;\n  _states                 : Map<mNT, JssmGenericState<mNT>>;\n  _edges                  : Array<JssmTransition<mNT, mDT>>;\n  _edge_map               : Map<mNT, Map<mNT, number>>;\n  _named_transitions      : Map<mNT, number>;\n  _actions                : Map<mNT, Map<mNT, number>>;\n  _reverse_actions        : Map<mNT, Map<mNT, number>>;\n  _reverse_action_targets : Map<mNT, Map<mNT, number>>;\n\n  _machine_author         : ?Array<string>;\n  _machine_comment        : ?string;\n  _machine_contributor    : ?Array<string>;\n  _machine_definition     : ?string;\n  _machine_language       : ?string;\n  _machine_license        : ?string;\n  _machine_name           : ?string;\n  _machine_version        : ?string;\n  _fsl_version            : ?string;\n  _raw_state_declaration  : ?Array<Object>;    // eslint-disable-line flowtype/no-weak-types\n  _state_declarations     : Map<mNT, JssmStateDeclaration<mNT>>;\n\n  _graph_layout           : JssmLayout;\n\n\n  // whargarbl this badly needs to be broken up, monolith master\n  constructor({\n    start_states,\n    complete        = [],\n    transitions,\n    machine_author,\n    machine_comment,\n    machine_contributor,\n    machine_definition,\n    machine_language,\n    machine_license,\n    machine_name,\n    machine_version,\n    state_declaration,\n    fsl_version,\n    graph_layout = 'dot'\n  } : JssmGenericConfig<mNT, mDT>) {\n\n    this._state                  = start_states[0];\n    this._states                 = new Map();\n    this._state_declarations     = new Map();\n    this._edges                  = [];\n    this._edge_map               = new Map();\n    this._named_transitions      = new Map();\n    this._actions                = new Map();\n    this._reverse_actions        = new Map();\n    this._reverse_action_targets = new Map();   // todo\n\n    this._machine_author         = machine_author;\n    this._machine_comment        = machine_comment;\n    this._machine_contributor    = machine_contributor;\n    this._machine_definition     = machine_definition;\n    this._machine_language       = machine_language;\n    this._machine_license        = machine_license;\n    this._machine_name           = machine_name;\n    this._machine_version        = machine_version;\n    this._raw_state_declaration  = state_declaration || [];\n    this._fsl_version            = fsl_version;\n\n    this._graph_layout           = graph_layout;\n\n\n    if (state_declaration) {\n      state_declaration.map( (state_decl: JssmStateDeclaration<mNT>) => {\n\n        if (this._state_declarations.has(state_decl.state)) { // no repeats\n          throw new Error(`Added the same state declaration twice: ${JSON.stringify(state_decl.state)}`);\n        }\n\n        this._state_declarations.set( state_decl.state, transfer_state_properties(state_decl) );\n\n      } );\n    }\n\n\n    transitions.map( (tr:JssmTransition<mNT, mDT>) => {\n\n      if (tr.from === undefined) { throw new Error(`transition must define 'from': ${JSON.stringify(tr)}`); }\n      if (tr.to   === undefined) { throw new Error(`transition must define 'to': ${  JSON.stringify(tr)}`); }\n\n      // get the cursors.  what a mess\n      const cursor_from: JssmGenericState<mNT>\n          = this._states.get(tr.from)\n         || { name: tr.from, from: [], to: [], complete: complete.includes(tr.from) };\n\n      if (!(this._states.has(tr.from))) {\n        this._new_state(cursor_from);\n      }\n\n      const cursor_to: JssmGenericState<mNT>\n          = this._states.get(tr.to)\n         || {name: tr.to, from: [], to: [], complete: complete.includes(tr.to) };\n\n      if (!(this._states.has(tr.to))) {\n        this._new_state(cursor_to);\n      }\n\n      // guard against existing connections being re-added\n      if (cursor_from.to.includes(tr.to)) {\n        throw new Error(`already has ${JSON.stringify(tr.from)} to ${JSON.stringify(tr.to)}`);\n      } else {\n        cursor_from.to.push(tr.to);\n        cursor_to.from.push(tr.from);\n      }\n\n      // add the edge; note its id\n      this._edges.push(tr);\n      const thisEdgeId: number = this._edges.length - 1;\n\n      // guard against repeating a transition name\n      if (tr.name) {\n        if (this._named_transitions.has(tr.name)) {\n          throw new Error(`named transition \"${JSON.stringify(tr.name)}\" already created`);\n        } else {\n          this._named_transitions.set(tr.name, thisEdgeId);\n        }\n      }\n\n      // set up the mapping, so that edges can be looked up by endpoint pairs\n      const from_mapping: Map<mNT, number> = this._edge_map.get(tr.from) || new Map();\n      if (!(this._edge_map.has(tr.from))) {\n        this._edge_map.set(tr.from, from_mapping);\n      }\n\n//    const to_mapping = from_mapping.get(tr.to);\n      from_mapping.set(tr.to, thisEdgeId); // already checked that this mapping doesn't exist, above\n\n      // set up the action mapping, so that actions can be looked up by origin\n      if (tr.action) {\n\n\n        // forward mapping first by action name\n        let actionMap: ?Map<mNT, number> = this._actions.get(tr.action);\n        if (!(actionMap)) {\n          actionMap = new Map();\n          this._actions.set(tr.action, actionMap);\n        }\n\n        if (actionMap.has(tr.from)) {\n          throw new Error(`action ${JSON.stringify(tr.action)} already attached to origin ${JSON.stringify(tr.from)}`);\n        } else {\n          actionMap.set(tr.from, thisEdgeId);\n        }\n\n\n        // reverse mapping first by state origin name\n        let rActionMap: ?Map<mNT, number> = this._reverse_actions.get(tr.from);\n        if (!(rActionMap)) {\n          rActionMap = new Map();\n          this._reverse_actions.set(tr.from, rActionMap);\n        }\n\n        // no need to test for reverse mapping pre-presence;\n        // forward mapping already covers collisions\n        rActionMap.set(tr.action, thisEdgeId);\n\n\n        // reverse mapping first by state target name\n        if (!(this._reverse_action_targets.has(tr.to))) {\n          this._reverse_action_targets.set(tr.to, new Map());\n        }\n\n/* todo comeback\n   fundamental problem is roActionMap needs to be a multimap\n        const roActionMap = this._reverse_action_targets.get(tr.to);  // wasteful - already did has - refactor\n        if (roActionMap) {\n          if (roActionMap.has(tr.action)) {\n            throw new Error(`ro-action ${tr.to} already attached to action ${tr.action}`);\n          } else {\n            roActionMap.set(tr.action, thisEdgeId);\n          }\n        } else {\n          throw new Error('should be impossible - flow doesn\\'t know .set precedes .get yet again.  severe error?');\n        }\n*/\n      }\n\n    });\n\n  }\n\n  _new_state(state_config: JssmGenericState<mNT>): mNT { // whargarbl get that state_config any under control\n\n    if (this._states.has(state_config.name)) {\n      throw new Error(`state ${JSON.stringify(state_config.name)} already exists`);\n    }\n\n    this._states.set(state_config.name, state_config);\n    return state_config.name;\n\n  }\n\n\n\n  state(): mNT {\n    return this._state;\n  }\n\n/* whargarbl todo major\n   when we reimplement this, reintroduce this change to the is_final call\n\n  is_changing(): boolean {\n    return true; // todo whargarbl\n  }\n*/\n\n\n  state_is_final(whichState: mNT): boolean {\n    return ( (this.state_is_terminal(whichState)) && (this.state_is_complete(whichState)) );\n  }\n\n  is_final(): boolean {\n//  return ((!this.is_changing()) && this.state_is_final(this.state()));\n    return this.state_is_final(this.state());\n  }\n\n  graph_layout(): string {\n    return this._graph_layout;\n  }\n\n\n\n  machine_author(): ?Array<string> {\n    return this._machine_author;\n  }\n\n  machine_comment(): ?string {\n    return this._machine_comment;\n  }\n\n  machine_contributor(): ?Array<string> {\n    return this._machine_contributor;\n  }\n\n  machine_definition(): ?string {\n    return this._machine_definition;\n  }\n\n  machine_language(): ?string {\n    return this._machine_language;\n  }\n\n  machine_license(): ?string {\n    return this._machine_license;\n  }\n\n  machine_name(): ?string {\n    return this._machine_name;\n  }\n\n  machine_version(): ?string {\n    return this._machine_version;\n  }\n\n  raw_state_declarations(): ?Array<Object> {    // eslint-disable-line flowtype/no-weak-types\n    return this._raw_state_declaration;\n  }\n\n  state_declaration(which: mNT): ?JssmStateDeclaration<mNT> {\n    return this._state_declarations.get(which);\n  }\n\n  state_declarations(): Map<mNT, Object> {    // eslint-disable-line flowtype/no-weak-types\n    return this._state_declarations;\n  }\n\n  fsl_version(): ?string {\n    return this._fsl_version;\n  }\n\n\n\n  machine_state(): JssmMachineInternalState<mNT, mDT> {\n\n    return {\n      internal_state_impl_version : 1,\n\n      actions                : this._actions,\n      edge_map               : this._edge_map,\n      edges                  : this._edges,\n      named_transitions      : this._named_transitions,\n      reverse_actions        : this._reverse_actions,\n//    reverse_action_targets : this._reverse_action_targets,\n      state                  : this._state,\n      states                 : this._states\n    };\n\n  }\n\n/*\n  load_machine_state(): boolean {\n    return false; // todo whargarbl\n  }\n*/\n\n\n  states(): Array<mNT> {\n    return [... this._states.keys()];\n  }\n\n  state_for(whichState: mNT): JssmGenericState<mNT> {\n    const state: ?JssmGenericState<mNT> = this._states.get(whichState);\n    if (state) { return state; }\n    else       { throw new Error(`no such state ${JSON.stringify(state)}`); }\n  }\n\n\n\n  list_edges(): Array< JssmTransition<mNT, mDT> > {\n    return this._edges;\n  }\n\n  list_named_transitions(): Map<mNT, number> {\n    return this._named_transitions;\n  }\n\n  list_actions(): Array<mNT> {\n    return [... this._actions.keys()];\n  }\n\n\n\n  get_transition_by_state_names(from: mNT, to: mNT): ?number {\n\n    const emg : ?Map<mNT, number> = this._edge_map.get(from);\n\n    if (emg) {\n      return emg.get(to);\n    } else {\n      return undefined;\n    }\n\n  }\n\n\n\n  lookup_transition_for(from: mNT, to: mNT): ?JssmTransition<mNT, mDT> {\n    const id : ?number = this.get_transition_by_state_names(from, to);\n    return ((id === undefined) || (id === null))? undefined : this._edges[id];\n  }\n\n\n\n  list_transitions(whichState: mNT = this.state()): JssmTransitionList<mNT> {\n    return {entrances: this.list_entrances(whichState), exits: this.list_exits(whichState)};\n  }\n\n  list_entrances(whichState: mNT = this.state()): Array<mNT> {\n    return (this._states.get(whichState) || {}).from || [];\n  }\n\n  list_exits(whichState: mNT = this.state()): Array<mNT> {\n    return (this._states.get(whichState) || {}).to   || [];\n  }\n\n\n\n  probable_exits_for(whichState: mNT): Array< JssmTransition<mNT, mDT> > {\n\n    const wstate: ?JssmGenericState<mNT> = this._states.get(whichState);\n    if (!(wstate)) { throw new Error(`No such state ${JSON.stringify(whichState)} in probable_exits_for`); }\n\n    const wstate_to : Array< mNT > = wstate.to,\n\n          wtf       : Array< JssmTransition<mNT, mDT> > // wstate_to_filtered -> wtf\n                    = wstate_to\n                        .map( (ws) : ?JssmTransition<mNT, mDT> => this.lookup_transition_for(this.state(), ws))\n                        .filter(Boolean);\n\n    return wtf;\n\n  }\n\n  probabilistic_transition(): boolean {\n    const selected : JssmTransition<mNT, mDT> = weighted_rand_select(this.probable_exits_for(this.state()));\n    return this.transition( selected.to );\n  }\n\n  probabilistic_walk(n: number): Array<mNT> {\n    return seq(n)\n          .map(() : mNT => {\n             const state_was: mNT = this.state();\n             this.probabilistic_transition();\n             return state_was;\n           })\n          .concat([this.state()]);\n  }\n\n  probabilistic_histo_walk(n: number): Map<mNT, number> {\n    return histograph(this.probabilistic_walk(n));\n  }\n\n\n\n  actions(whichState: mNT = this.state() ): Array<mNT> {\n    const wstate : ?Map<mNT, number> = this._reverse_actions.get(whichState);\n    if (wstate) { return [... wstate.keys()]; }\n    else        { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n  }\n\n  list_states_having_action(whichState: mNT): Array<mNT> {\n    const wstate : ?Map<mNT, number> = this._actions.get(whichState);\n    if (wstate) { return [... wstate.keys()]; }\n    else        { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n  }\n\n// comeback\n/*\n  list_entrance_actions(whichState: mNT = this.state() ) : Array<mNT> {\n    return [... (this._reverse_action_targets.get(whichState) || new Map()).values()] // wasteful\n           .map( (edgeId:any) => (this._edges[edgeId] : any)) // whargarbl burn out any\n           .filter( (o:any) => o.to === whichState)\n           .map( filtered => filtered.from );\n  }\n*/\n  list_exit_actions(whichState: mNT = this.state() ): Array<?mNT> { // these are mNT, not ?mNT\n    const ra_base: ?Map<mNT, number> = this._reverse_actions.get(whichState);\n    if (!(ra_base)) { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n\n    return [... ra_base.values()]\n           .map    ( (edgeId: number)              : JssmTransition<mNT, mDT> => this._edges[edgeId]   )\n           .filter ( (o: JssmTransition<mNT, mDT>) : boolean                  => o.from === whichState )\n           .map    ( (filtered: JssmTransition<mNT, mDT>) : ?mNT              => filtered.action       );\n  }\n\n  probable_action_exits(whichState: mNT = this.state() ) : Array<mixed> { // these are mNT\n    const ra_base: ?Map<mNT, number> = this._reverse_actions.get(whichState);\n    if (!(ra_base)) { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n\n    return [... ra_base.values()]\n           .map    ( (edgeId: number): JssmTransition<mNT, mDT> => this._edges[edgeId]   )\n           .filter ( (o: JssmTransition<mNT, mDT>): boolean     => o.from === whichState )\n           .map    ( (filtered): mixed                          => ( { action      : filtered.action,\n                                                                       probability : filtered.probability } )\n                                                                   );\n  }\n\n\n\n  is_unenterable(whichState: mNT): boolean {\n    // whargarbl should throw on unknown state\n    return this.list_entrances(whichState).length === 0;\n  }\n\n  has_unenterables(): boolean {\n    return this.states().some( (x): boolean => this.is_unenterable(x));\n  }\n\n\n\n  is_terminal(): boolean {\n    return this.state_is_terminal(this.state());\n  }\n\n  state_is_terminal(whichState: mNT): boolean {\n    // whargarbl should throw on unknown state\n    return this.list_exits(whichState).length === 0;\n  }\n\n  has_terminals(): boolean {\n    return this.states().some( (x): boolean => this.state_is_terminal(x));\n  }\n\n\n\n  is_complete(): boolean {\n    return this.state_is_complete(this.state());\n  }\n\n  state_is_complete(whichState: mNT) : boolean {\n    const wstate: ?JssmGenericState<mNT> = this._states.get(whichState);\n    if (wstate) { return wstate.complete; }\n    else        { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n  }\n\n  has_completes(): boolean {\n    return this.states().some( (x): boolean => this.state_is_complete(x) );\n  }\n\n\n\n  action(name: mNT, newData?: mDT): boolean {\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    if (this.valid_action(name, newData)) {\n      const edge: JssmTransition<mNT, mDT> = this.current_action_edge_for(name);\n      this._state = edge.to;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  transition(newState: mNT, newData?: mDT): boolean {\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    if (this.valid_transition(newState, newData)) {\n      this._state = newState;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  // can leave machine in inconsistent state.  generally do not use\n  force_transition(newState: mNT, newData?: mDT): boolean {\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    if (this.valid_force_transition(newState, newData)) {\n      this._state = newState;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n\n\n  current_action_for(action: mNT): number | void {\n    const action_base: ?Map<mNT, number> = this._actions.get(action);\n    return action_base? action_base.get(this.state()): undefined;\n  }\n\n  current_action_edge_for(action: mNT): JssmTransition<mNT, mDT> {\n    const idx: ?number = this.current_action_for(action);\n    if ((idx === undefined) || (idx === null)) { throw new Error(`No such action ${JSON.stringify(action)}`); }\n    return this._edges[idx];\n  }\n\n  valid_action(action: mNT, _newData?: mDT): boolean {  // todo comeback unignore newData\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    return this.current_action_for(action) !== undefined;\n  }\n\n  valid_transition(newState: mNT, _newData?: mDT): boolean {  // todo comeback unignore newData\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    const transition_for: ?JssmTransition<mNT, mDT> = this.lookup_transition_for(this.state(), newState);\n\n    if (!(transition_for))          { return false; }\n    if (transition_for.forced_only) { return false; }\n\n    return true;\n\n  }\n\n  valid_force_transition(newState: mNT, _newData?: mDT): boolean {  // todo comeback unignore newData\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    return (this.lookup_transition_for(this.state(), newState) !== undefined);\n  }\n\n\n}\n\n\n\n\n\nfunction sm<mNT, mDT>(template_strings: Array<string> /* , arguments */): Machine<mNT, mDT> {\n\n    // foo`a${1}b${2}c` will come in as (['a','b','c'],1,2)\n    // this includes when a and c are empty strings\n    // therefore template_strings will always have one more el than template_args\n    // therefore map the smaller container and toss the last one on on the way out\n\n    return new Machine(make(template_strings.reduce(\n\n      // in general avoiding `arguments` is smart.  however with the template\n      // string notation, as designed, it's not really worth the hassle\n\n      /* eslint-disable fp/no-arguments */\n      /* eslint-disable prefer-rest-params */\n      (acc, val, idx): string => `${acc}${arguments[idx]}${val}`  // arguments[0] is never loaded, so args doesn't need to be gated\n      /* eslint-enable  prefer-rest-params */\n      /* eslint-enable  fp/no-arguments */\n\n    )));\n\n}\n\n\n\n\n\nexport {\n\n  version,\n\n  transfer_state_properties,\n\n  Machine,\n\n  make,\n    parse,\n    compile,\n\n  sm,\n\n  arrow_direction,\n  arrow_left_kind,\n  arrow_right_kind,\n\n  // todo whargarbl these should be exported to a utility library\n  seq, weighted_rand_select, histograph, weighted_sample_select, weighted_histo_key\n\n};\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/js/jssm.js"],"names":["reduce_to_639","require","reduce","parse","version","arrow_direction","arrow","String","Error","arrow_left_kind","arrow_right_kind","makeTransition","this_se","from","to","isRight","wasList","wasIndex","kind","edge","forced_only","main_path","undefined","action","probability","compile_rule_transition_step","acc","next_se","edges","uFrom","Array","isArray","uTo","map","f","t","right","push","left","new_acc","concat","se","compile_rule_handle_transition","rule","compile_rule_handler","key","agg_as","val","value","name","state","declarations","tautologies","includes","JSON","stringify","compile","tree","results","graph_layout","transition","start_states","end_states","state_declaration","fsl_version","machine_author","machine_comment","machine_contributor","machine_definition","machine_language","machine_license","machine_name","machine_reference","machine_version","tr","assembled_transitions","result_cfg","length","transitions","oneOnlyKeys","oneOnlyKey","multiKey","make","plan","transfer_state_properties","state_decl","d","node_shape","node_color","Machine","complete","_state","_states","Map","_state_declarations","_edges","_edge_map","_named_transitions","_actions","_reverse_actions","_reverse_action_targets","_machine_author","_machine_comment","_machine_contributor","_machine_definition","_machine_language","_machine_license","_machine_name","_machine_version","_raw_state_declaration","_fsl_version","_graph_layout","has","set","cursor_from","get","_new_state","cursor_to","thisEdgeId","from_mapping","actionMap","rActionMap","state_config","whichState","state_is_terminal","state_is_complete","state_is_final","which","internal_state_impl_version","actions","edge_map","named_transitions","reverse_actions","states","keys","emg","id","get_transition_by_state_names","entrances","list_entrances","exits","list_exits","wstate","wstate_to","wtf","ws","lookup_transition_for","filter","Boolean","selected","probable_exits_for","n","state_was","probabilistic_transition","probabilistic_walk","ra_base","values","edgeId","o","filtered","some","x","is_unenterable","newData","valid_action","current_action_edge_for","newState","valid_transition","valid_force_transition","action_base","idx","current_action_for","_newData","transition_for","sm","template_strings","seq","weighted_rand_select","histograph","weighted_sample_select","weighted_histo_key"],"mappings":"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","file":"jssm.js","sourcesContent":["\n// whargarbl lots of these return arrays could/should be sets\n\n// @flow\n\nconst reduce_to_639 : Function = require('reduce-to-639-1').reduce;\n\n\n\n\n\nimport type {\n\n  JssmGenericState, JssmGenericConfig,\n  JssmTransition, JssmTransitionList, JssmTransitionRule,\n  JssmMachineInternalState,\n  JssmParseTree,\n  JssmStateDeclaration, JssmStateDeclarationRule,\n  JssmCompileSe, JssmCompileSeStart, JssmCompileRule,\n  JssmArrow, JssmArrowDirection, JssmArrowKind,\n  JssmLayout\n\n} from './jssm-types';\n\n\n\n\n\nimport { seq, weighted_rand_select, weighted_sample_select, histograph, weighted_histo_key } from './jssm-util.js';\n\nconst parse: Function = require('./jssm-dot.js').parse;  // eslint-disable-line flowtype/no-weak-types // todo whargarbl remove any\n\nconst version: null = null; // replaced from package.js in build\n\n\n\n\n\n/* eslint-disable complexity */\n\nfunction arrow_direction(arrow: JssmArrow): JssmArrowDirection {\n\n  switch ( String(arrow) ) {\n\n    case '->'   :      case '→'  :\n    case '=>'   :      case '⇒'  :\n    case '~>'   :      case '↛'  :\n      return 'right';\n\n    case '<-'   :      case '←'  :\n    case '<='   :      case '⇐'  :\n    case '<~'   :      case '↚'  :\n      return 'left';\n\n    case '<->'  :      case '↔'  :\n    case '<-=>' :      case '←⇒' :      case '←=>' :      case '<-⇒' :\n    case '<-~>' :      case '←↛' :      case '←~>' :      case '<-↛' :\n\n    case '<=>'  :      case '⇔'  :\n    case '<=->' :      case '⇐→' :      case '⇐->' :      case '<=→' :\n    case '<=~>' :      case '⇐↛' :      case '⇐~>' :      case '<=↛' :\n\n    case '<~>'  :      case '↮'  :\n    case '<~->' :      case '↚→' :      case '↚->' :      case '<~→' :\n    case '<~=>' :      case '↚⇒' :      case '↚=>' :      case '<~⇒' :\n      return 'both';\n\n    default:\n      throw new Error(`arrow_direction: unknown arrow type ${arrow}`);\n\n  }\n\n}\n\n/* eslint-enable complexity */\n\n\n\n\n\n/* eslint-disable complexity */\n\nfunction arrow_left_kind(arrow: JssmArrow): JssmArrowKind {\n\n  switch ( String(arrow) ) {\n\n    case '->' :    case '→' :\n    case '=>' :    case '⇒' :\n    case '~>' :    case '↛' :\n      return 'none';\n\n    case '<-':     case '←' :\n    case '<->':    case '↔' :\n    case '<-=>':   case '←⇒' :\n    case '<-~>':   case '←↛' :\n      return 'legal';\n\n    case '<=':     case '⇐' :\n    case '<=>':    case '⇔' :\n    case '<=->':   case '⇐→' :\n    case '<=~>':   case '⇐↛' :\n      return 'main';\n\n    case '<~':     case '↚' :\n    case '<~>':    case '↮' :\n    case '<~->':   case '↚→' :\n    case '<~=>':   case '↚⇒' :\n      return 'forced';\n\n    default:\n      throw new Error(`arrow_direction: unknown arrow type ${arrow}`);\n\n  }\n\n}\n\n/* eslint-enable complexity */\n\n\n\n\n\n/* eslint-disable complexity */\n\nfunction arrow_right_kind(arrow: JssmArrow): JssmArrowKind {\n\n  switch ( String(arrow) ) {\n\n    case '<-' :    case '←' :\n    case '<=' :    case '⇐' :\n    case '<~' :    case '↚' :\n      return 'none';\n\n    case '->' :    case '→' :\n    case '<->':    case '↔' :\n    case '<=->':   case '⇐→' :\n    case '<~->':   case '↚→' :\n      return 'legal';\n\n    case '=>' :    case '⇒' :\n    case '<=>':    case '⇔' :\n    case '<-=>':   case '←⇒' :\n    case '<~=>':   case '↚⇒' :\n      return 'main';\n\n    case '~>' :    case '↛' :\n    case '<~>':    case '↮' :\n    case '<-~>':   case '←↛' :\n    case '<=~>':   case '⇐↛' :\n      return 'forced';\n\n    default:\n      throw new Error(`arrow_direction: unknown arrow type ${arrow}`);\n\n  }\n\n}\n\n/* eslint-enable complexity */\n\n\n\n\n\nfunction makeTransition<mNT, mDT>(\n  this_se   : JssmCompileSe<mNT>,\n  from      : mNT,\n  to        : mNT,\n  isRight   : boolean,\n  wasList?  : Array<mNT>,\n  wasIndex? : number\n) : JssmTransition<mNT, mDT> {\n\n  const kind : JssmArrowKind            = isRight? arrow_right_kind(this_se.kind) : arrow_left_kind(this_se.kind),\n        edge : JssmTransition<mNT, mDT> = {\n          from,\n          to,\n          kind,\n          forced_only : kind === 'forced',\n          main_path   : kind === 'main'\n        };\n\n  if ((wasList  !== undefined) && (wasIndex === undefined)) { throw \"Must have an index if transition was in a list\"; }\n  if ((wasIndex !== undefined) && (wasList  === undefined)) { throw \"Must be in a list if transition has an index\";   }\n/*\n  if (typeof edge.to === 'object') {\n\n    if (edge.to.key === 'cycle') {\n      if (wasList === undefined) { throw \"Must have a waslist if a to is type cycle\"; }\n      const nextIndex = wrapBy(wasIndex, edge.to.value, wasList.length);\n      edge.to = wasList[nextIndex];\n    }\n\n  }\n*/\n  const action      : string = isRight? 'r_action'      : 'l_action',\n        probability : string = isRight? 'r_probability' : 'l_probability';\n\n  if (this_se[action])      { edge.action      = this_se[action];      }\n  if (this_se[probability]) { edge.probability = this_se[probability]; }\n\n  return edge;\n\n}\n\n\n\n\n\nfunction compile_rule_transition_step<mNT, mDT>(\n             acc     : Array< JssmTransition<mNT, mDT> >,\n             from    : mNT,\n             to      : mNT,\n             this_se : JssmCompileSe<mNT>,\n             next_se : JssmCompileSe<mNT>\n         ) : Array< JssmTransition<mNT, mDT> > { // todo flow describe the parser representation of a transition step extension\n\n  const edges : Array< JssmTransition<mNT, mDT> > = [];\n\n  const uFrom : Array< mNT > = (Array.isArray(from)? from : [from]),\n        uTo   : Array< mNT > = (Array.isArray(to)?   to   : [to]  );\n\n  uFrom.map( (f: mNT) => {\n    uTo.map( (t: mNT) => {\n\n      const right: JssmTransition<mNT, mDT> = makeTransition(this_se, f, t, true);\n      if (right.kind !== 'none') { edges.push(right); }\n\n      const left: JssmTransition<mNT, mDT> = makeTransition(this_se, t, f, false);\n      if (left.kind !== 'none') { edges.push(left); }\n\n    });\n  });\n\n  const new_acc: Array< JssmTransition<mNT, mDT> > = acc.concat(edges);\n\n  if (next_se) {\n    return compile_rule_transition_step(new_acc, to, next_se.to, next_se, next_se.se);\n  } else {\n    return new_acc;\n  }\n\n}\n\n\n\nfunction compile_rule_handle_transition<mNT>(rule: JssmCompileSeStart<mNT>): mixed { // todo flow describe the parser representation of a transition\n  return compile_rule_transition_step([], rule.from, rule.se.to, rule.se, rule.se.se);\n}\n\n\n\nfunction compile_rule_handler<mNT>(rule: JssmCompileSeStart<mNT>): JssmCompileRule { // todo flow describe the output of the parser\n\n  if (rule.key === 'transition') {\n    return { agg_as: 'transition', val: compile_rule_handle_transition(rule) };\n  }\n\n  if (rule.key === 'machine_language') {\n    return { agg_as: 'machine_language', val: reduce_to_639(rule.value) };\n  }\n\n  if (rule.key === 'state_declaration') {\n    if (!rule.name) { throw new Error('State declarations must have a name'); }\n    return { agg_as: 'state_declaration', val: { state: rule.name, declarations: rule.value } };\n  }\n\n  const tautologies : Array<string> = [\n    'graph_layout', 'start_states', 'end_states', 'machine_name', 'machine_version',\n    'machine_comment', 'machine_author', 'machine_contributor', 'machine_definition',\n    'machine_reference', 'machine_license', 'fsl_version'\n  ];\n\n  if (tautologies.includes(rule.key)) {\n    return { agg_as: rule.key, val: rule.value };\n  }\n\n  throw new Error(`compile_rule_handler: Unknown rule: ${JSON.stringify(rule)}`);\n\n}\n\n\n\n\n\nfunction compile<mNT, mDT>(tree: JssmParseTree<mNT>): JssmGenericConfig<mNT, mDT> {  // todo flow describe the output of the parser\n\n  const results : {\n    graph_layout        : Array< JssmLayout >,\n    transition          : Array< JssmTransition<mNT, mDT> >,\n    start_states        : Array< mNT >,\n    end_states          : Array< mNT >,\n    state_declaration   : Array< mNT >,\n    fsl_version         : Array< string >,\n    machine_author      : Array< string >,\n    machine_comment     : Array< string >,\n    machine_contributor : Array< string >,\n    machine_definition  : Array< string >,\n    machine_language    : Array< string >,\n    machine_license     : Array< string >,\n    machine_name        : Array< string >,\n    machine_reference   : Array< string >,\n    machine_version     : Array< string > // semver\n  } = {\n    graph_layout        : [],\n    transition          : [],\n    start_states        : [],\n    end_states          : [],\n    state_declaration   : [],\n    fsl_version         : [],\n    machine_author      : [],\n    machine_comment     : [],\n    machine_contributor : [],\n    machine_definition  : [],\n    machine_language    : [],\n    machine_license     : [],\n    machine_name        : [],\n    machine_reference   : [],\n    machine_version     : []\n  };\n\n  tree.map( (tr : JssmCompileSeStart<mNT>) => {\n\n    const rule   : JssmCompileRule = compile_rule_handler(tr),\n          agg_as : string          = rule.agg_as,\n          val    : mixed           = rule.val;                  // todo better types\n\n    results[agg_as] = results[agg_as].concat(val);\n\n  });\n\n  const assembled_transitions : Array< JssmTransition<mNT, mDT> > = [].concat(... results['transition']);\n\n  const result_cfg : JssmGenericConfig<mNT, mDT> = {\n    start_states : results.start_states.length? results.start_states : [assembled_transitions[0].from],\n    transitions  : assembled_transitions\n  };\n\n  const oneOnlyKeys : Array<string> = [\n    'graph_layout', 'machine_name', 'machine_version', 'machine_comment', 'fsl_version', 'machine_license',\n    'machine_definition', 'machine_language'\n  ];\n\n  oneOnlyKeys.map( (oneOnlyKey : string) => {\n    if (results[oneOnlyKey].length > 1) {\n      throw new Error(`May only have one ${oneOnlyKey} statement maximum: ${JSON.stringify(results[oneOnlyKey])}`);\n    } else {\n      if (results[oneOnlyKey].length) {\n        result_cfg[oneOnlyKey] = results[oneOnlyKey][0];\n      }\n    }\n  });\n\n  ['machine_author', 'machine_contributor', 'machine_reference', 'state_declaration'].map( (multiKey : string) => {\n    if (results[multiKey].length) {\n      result_cfg[multiKey] = results[multiKey];\n    }\n  });\n\n  return result_cfg;\n\n}\n\n\n\n\n\nfunction make<mNT, mDT>(plan: string): JssmGenericConfig<mNT, mDT> {\n  return compile(parse(plan));\n}\n\n\n\n\n\nfunction transfer_state_properties<mNT>(state_decl: JssmStateDeclaration<mNT>): JssmStateDeclaration<mNT> {\n\n    state_decl.declarations.map( (d: JssmStateDeclarationRule) => {\n      switch (d.key) {\n\n        case 'node_shape' : state_decl.node_shape = d.value; break;\n        case 'node_color' : state_decl.node_color = d.value; break;\n\n        default: throw new Error(`Unknown state property: '${JSON.stringify(d)}'`);\n\n      }\n    });\n\n    return state_decl;\n\n}\n\n\n\n\n\nclass Machine<mNT, mDT> {\n\n\n  _state                  : mNT;\n  _states                 : Map<mNT, JssmGenericState<mNT>>;\n  _edges                  : Array<JssmTransition<mNT, mDT>>;\n  _edge_map               : Map<mNT, Map<mNT, number>>;\n  _named_transitions      : Map<mNT, number>;\n  _actions                : Map<mNT, Map<mNT, number>>;\n  _reverse_actions        : Map<mNT, Map<mNT, number>>;\n  _reverse_action_targets : Map<mNT, Map<mNT, number>>;\n\n  _machine_author         : ?Array<string>;\n  _machine_comment        : ?string;\n  _machine_contributor    : ?Array<string>;\n  _machine_definition     : ?string;\n  _machine_language       : ?string;\n  _machine_license        : ?string;\n  _machine_name           : ?string;\n  _machine_version        : ?string;\n  _fsl_version            : ?string;\n  _raw_state_declaration  : ?Array<Object>;    // eslint-disable-line flowtype/no-weak-types\n  _state_declarations     : Map<mNT, JssmStateDeclaration<mNT>>;\n\n  _graph_layout           : JssmLayout;\n\n\n  // whargarbl this badly needs to be broken up, monolith master\n  constructor({\n    start_states,\n    complete        = [],\n    transitions,\n    machine_author,\n    machine_comment,\n    machine_contributor,\n    machine_definition,\n    machine_language,\n    machine_license,\n    machine_name,\n    machine_version,\n    state_declaration,\n    fsl_version,\n    graph_layout = 'dot'\n  } : JssmGenericConfig<mNT, mDT>) {\n\n    this._state                  = start_states[0];\n    this._states                 = new Map();\n    this._state_declarations     = new Map();\n    this._edges                  = [];\n    this._edge_map               = new Map();\n    this._named_transitions      = new Map();\n    this._actions                = new Map();\n    this._reverse_actions        = new Map();\n    this._reverse_action_targets = new Map();   // todo\n\n    this._machine_author         = machine_author;\n    this._machine_comment        = machine_comment;\n    this._machine_contributor    = machine_contributor;\n    this._machine_definition     = machine_definition;\n    this._machine_language       = machine_language;\n    this._machine_license        = machine_license;\n    this._machine_name           = machine_name;\n    this._machine_version        = machine_version;\n    this._raw_state_declaration  = state_declaration || [];\n    this._fsl_version            = fsl_version;\n\n    this._graph_layout           = graph_layout;\n\n\n    if (state_declaration) {\n      state_declaration.map( (state_decl: JssmStateDeclaration<mNT>) => {\n\n        if (this._state_declarations.has(state_decl.state)) { // no repeats\n          throw new Error(`Added the same state declaration twice: ${JSON.stringify(state_decl.state)}`);\n        }\n\n        this._state_declarations.set( state_decl.state, transfer_state_properties(state_decl) );\n\n      } );\n    }\n\n\n    transitions.map( (tr:JssmTransition<mNT, mDT>) => {\n\n      if (tr.from === undefined) { throw new Error(`transition must define 'from': ${JSON.stringify(tr)}`); }\n      if (tr.to   === undefined) { throw new Error(`transition must define 'to': ${  JSON.stringify(tr)}`); }\n\n      // get the cursors.  what a mess\n      const cursor_from: JssmGenericState<mNT>\n          = this._states.get(tr.from)\n         || { name: tr.from, from: [], to: [], complete: complete.includes(tr.from) };\n\n      if (!(this._states.has(tr.from))) {\n        this._new_state(cursor_from);\n      }\n\n      const cursor_to: JssmGenericState<mNT>\n          = this._states.get(tr.to)\n         || {name: tr.to, from: [], to: [], complete: complete.includes(tr.to) };\n\n      if (!(this._states.has(tr.to))) {\n        this._new_state(cursor_to);\n      }\n\n      // guard against existing connections being re-added\n      if (cursor_from.to.includes(tr.to)) {\n        throw new Error(`already has ${JSON.stringify(tr.from)} to ${JSON.stringify(tr.to)}`);\n      } else {\n        cursor_from.to.push(tr.to);\n        cursor_to.from.push(tr.from);\n      }\n\n      // add the edge; note its id\n      this._edges.push(tr);\n      const thisEdgeId: number = this._edges.length - 1;\n\n      // guard against repeating a transition name\n      if (tr.name) {\n        if (this._named_transitions.has(tr.name)) {\n          throw new Error(`named transition \"${JSON.stringify(tr.name)}\" already created`);\n        } else {\n          this._named_transitions.set(tr.name, thisEdgeId);\n        }\n      }\n\n      // set up the mapping, so that edges can be looked up by endpoint pairs\n      const from_mapping: Map<mNT, number> = this._edge_map.get(tr.from) || new Map();\n      if (!(this._edge_map.has(tr.from))) {\n        this._edge_map.set(tr.from, from_mapping);\n      }\n\n//    const to_mapping = from_mapping.get(tr.to);\n      from_mapping.set(tr.to, thisEdgeId); // already checked that this mapping doesn't exist, above\n\n      // set up the action mapping, so that actions can be looked up by origin\n      if (tr.action) {\n\n\n        // forward mapping first by action name\n        let actionMap: ?Map<mNT, number> = this._actions.get(tr.action);\n        if (!(actionMap)) {\n          actionMap = new Map();\n          this._actions.set(tr.action, actionMap);\n        }\n\n        if (actionMap.has(tr.from)) {\n          throw new Error(`action ${JSON.stringify(tr.action)} already attached to origin ${JSON.stringify(tr.from)}`);\n        } else {\n          actionMap.set(tr.from, thisEdgeId);\n        }\n\n\n        // reverse mapping first by state origin name\n        let rActionMap: ?Map<mNT, number> = this._reverse_actions.get(tr.from);\n        if (!(rActionMap)) {\n          rActionMap = new Map();\n          this._reverse_actions.set(tr.from, rActionMap);\n        }\n\n        // no need to test for reverse mapping pre-presence;\n        // forward mapping already covers collisions\n        rActionMap.set(tr.action, thisEdgeId);\n\n\n        // reverse mapping first by state target name\n        if (!(this._reverse_action_targets.has(tr.to))) {\n          this._reverse_action_targets.set(tr.to, new Map());\n        }\n\n/* todo comeback\n   fundamental problem is roActionMap needs to be a multimap\n        const roActionMap = this._reverse_action_targets.get(tr.to);  // wasteful - already did has - refactor\n        if (roActionMap) {\n          if (roActionMap.has(tr.action)) {\n            throw new Error(`ro-action ${tr.to} already attached to action ${tr.action}`);\n          } else {\n            roActionMap.set(tr.action, thisEdgeId);\n          }\n        } else {\n          throw new Error('should be impossible - flow doesn\\'t know .set precedes .get yet again.  severe error?');\n        }\n*/\n      }\n\n    });\n\n  }\n\n  _new_state(state_config: JssmGenericState<mNT>): mNT { // whargarbl get that state_config any under control\n\n    if (this._states.has(state_config.name)) {\n      throw new Error(`state ${JSON.stringify(state_config.name)} already exists`);\n    }\n\n    this._states.set(state_config.name, state_config);\n    return state_config.name;\n\n  }\n\n\n\n  state(): mNT {\n    return this._state;\n  }\n\n/* whargarbl todo major\n   when we reimplement this, reintroduce this change to the is_final call\n\n  is_changing(): boolean {\n    return true; // todo whargarbl\n  }\n*/\n\n\n  state_is_final(whichState: mNT): boolean {\n    return ( (this.state_is_terminal(whichState)) && (this.state_is_complete(whichState)) );\n  }\n\n  is_final(): boolean {\n//  return ((!this.is_changing()) && this.state_is_final(this.state()));\n    return this.state_is_final(this.state());\n  }\n\n  graph_layout(): string {\n    return this._graph_layout;\n  }\n\n\n\n  machine_author(): ?Array<string> {\n    return this._machine_author;\n  }\n\n  machine_comment(): ?string {\n    return this._machine_comment;\n  }\n\n  machine_contributor(): ?Array<string> {\n    return this._machine_contributor;\n  }\n\n  machine_definition(): ?string {\n    return this._machine_definition;\n  }\n\n  machine_language(): ?string {\n    return this._machine_language;\n  }\n\n  machine_license(): ?string {\n    return this._machine_license;\n  }\n\n  machine_name(): ?string {\n    return this._machine_name;\n  }\n\n  machine_version(): ?string {\n    return this._machine_version;\n  }\n\n  raw_state_declarations(): ?Array<Object> {    // eslint-disable-line flowtype/no-weak-types\n    return this._raw_state_declaration;\n  }\n\n  state_declaration(which: mNT): ?JssmStateDeclaration<mNT> {\n    return this._state_declarations.get(which);\n  }\n\n  state_declarations(): Map<mNT, Object> {    // eslint-disable-line flowtype/no-weak-types\n    return this._state_declarations;\n  }\n\n  fsl_version(): ?string {\n    return this._fsl_version;\n  }\n\n\n\n  machine_state(): JssmMachineInternalState<mNT, mDT> {\n\n    return {\n      internal_state_impl_version : 1,\n\n      actions                : this._actions,\n      edge_map               : this._edge_map,\n      edges                  : this._edges,\n      named_transitions      : this._named_transitions,\n      reverse_actions        : this._reverse_actions,\n//    reverse_action_targets : this._reverse_action_targets,\n      state                  : this._state,\n      states                 : this._states\n    };\n\n  }\n\n/*\n  load_machine_state(): boolean {\n    return false; // todo whargarbl\n  }\n*/\n\n\n  states(): Array<mNT> {\n    return [... this._states.keys()];\n  }\n\n  state_for(whichState: mNT): JssmGenericState<mNT> {\n    const state: ?JssmGenericState<mNT> = this._states.get(whichState);\n    if (state) { return state; }\n    else       { throw new Error(`no such state ${JSON.stringify(state)}`); }\n  }\n\n\n\n  list_edges(): Array< JssmTransition<mNT, mDT> > {\n    return this._edges;\n  }\n\n  list_named_transitions(): Map<mNT, number> {\n    return this._named_transitions;\n  }\n\n  list_actions(): Array<mNT> {\n    return [... this._actions.keys()];\n  }\n\n\n\n  get_transition_by_state_names(from: mNT, to: mNT): ?number {\n\n    const emg : ?Map<mNT, number> = this._edge_map.get(from);\n\n    if (emg) {\n      return emg.get(to);\n    } else {\n      return undefined;\n    }\n\n  }\n\n\n\n  lookup_transition_for(from: mNT, to: mNT): ?JssmTransition<mNT, mDT> {\n    const id : ?number = this.get_transition_by_state_names(from, to);\n    return ((id === undefined) || (id === null))? undefined : this._edges[id];\n  }\n\n\n\n  list_transitions(whichState: mNT = this.state()): JssmTransitionList<mNT> {\n    return {entrances: this.list_entrances(whichState), exits: this.list_exits(whichState)};\n  }\n\n  list_entrances(whichState: mNT = this.state()): Array<mNT> {\n    return (this._states.get(whichState) || {}).from || [];\n  }\n\n  list_exits(whichState: mNT = this.state()): Array<mNT> {\n    return (this._states.get(whichState) || {}).to   || [];\n  }\n\n\n\n  probable_exits_for(whichState: mNT): Array< JssmTransition<mNT, mDT> > {\n\n    const wstate: ?JssmGenericState<mNT> = this._states.get(whichState);\n    if (!(wstate)) { throw new Error(`No such state ${JSON.stringify(whichState)} in probable_exits_for`); }\n\n    const wstate_to : Array< mNT > = wstate.to,\n\n          wtf       : Array< JssmTransition<mNT, mDT> > // wstate_to_filtered -> wtf\n                    = wstate_to\n                        .map( (ws) : ?JssmTransition<mNT, mDT> => this.lookup_transition_for(this.state(), ws))\n                        .filter(Boolean);\n\n    return wtf;\n\n  }\n\n  probabilistic_transition(): boolean {\n    const selected : JssmTransition<mNT, mDT> = weighted_rand_select(this.probable_exits_for(this.state()));\n    return this.transition( selected.to );\n  }\n\n  probabilistic_walk(n: number): Array<mNT> {\n    return seq(n)\n          .map(() : mNT => {\n             const state_was: mNT = this.state();\n             this.probabilistic_transition();\n             return state_was;\n           })\n          .concat([this.state()]);\n  }\n\n  probabilistic_histo_walk(n: number): Map<mNT, number> {\n    return histograph(this.probabilistic_walk(n));\n  }\n\n\n\n  actions(whichState: mNT = this.state() ): Array<mNT> {\n    const wstate : ?Map<mNT, number> = this._reverse_actions.get(whichState);\n    if (wstate) { return [... wstate.keys()]; }\n    else        { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n  }\n\n  list_states_having_action(whichState: mNT): Array<mNT> {\n    const wstate : ?Map<mNT, number> = this._actions.get(whichState);\n    if (wstate) { return [... wstate.keys()]; }\n    else        { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n  }\n\n// comeback\n/*\n  list_entrance_actions(whichState: mNT = this.state() ) : Array<mNT> {\n    return [... (this._reverse_action_targets.get(whichState) || new Map()).values()] // wasteful\n           .map( (edgeId:any) => (this._edges[edgeId] : any)) // whargarbl burn out any\n           .filter( (o:any) => o.to === whichState)\n           .map( filtered => filtered.from );\n  }\n*/\n  list_exit_actions(whichState: mNT = this.state() ): Array<?mNT> { // these are mNT, not ?mNT\n    const ra_base: ?Map<mNT, number> = this._reverse_actions.get(whichState);\n    if (!(ra_base)) { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n\n    return [... ra_base.values()]\n           .map    ( (edgeId: number)              : JssmTransition<mNT, mDT> => this._edges[edgeId]   )\n           .filter ( (o: JssmTransition<mNT, mDT>) : boolean                  => o.from === whichState )\n           .map    ( (filtered: JssmTransition<mNT, mDT>) : ?mNT              => filtered.action       );\n  }\n\n  probable_action_exits(whichState: mNT = this.state() ) : Array<mixed> { // these are mNT\n    const ra_base: ?Map<mNT, number> = this._reverse_actions.get(whichState);\n    if (!(ra_base)) { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n\n    return [... ra_base.values()]\n           .map    ( (edgeId: number): JssmTransition<mNT, mDT> => this._edges[edgeId]   )\n           .filter ( (o: JssmTransition<mNT, mDT>): boolean     => o.from === whichState )\n           .map    ( (filtered): mixed                          => ( { action      : filtered.action,\n                                                                       probability : filtered.probability } )\n                                                                   );\n  }\n\n\n\n  is_unenterable(whichState: mNT): boolean {\n    // whargarbl should throw on unknown state\n    return this.list_entrances(whichState).length === 0;\n  }\n\n  has_unenterables(): boolean {\n    return this.states().some( (x): boolean => this.is_unenterable(x));\n  }\n\n\n\n  is_terminal(): boolean {\n    return this.state_is_terminal(this.state());\n  }\n\n  state_is_terminal(whichState: mNT): boolean {\n    // whargarbl should throw on unknown state\n    return this.list_exits(whichState).length === 0;\n  }\n\n  has_terminals(): boolean {\n    return this.states().some( (x): boolean => this.state_is_terminal(x));\n  }\n\n\n\n  is_complete(): boolean {\n    return this.state_is_complete(this.state());\n  }\n\n  state_is_complete(whichState: mNT) : boolean {\n    const wstate: ?JssmGenericState<mNT> = this._states.get(whichState);\n    if (wstate) { return wstate.complete; }\n    else        { throw new Error(`No such state ${JSON.stringify(whichState)}`); }\n  }\n\n  has_completes(): boolean {\n    return this.states().some( (x): boolean => this.state_is_complete(x) );\n  }\n\n\n\n  action(name: mNT, newData?: mDT): boolean {\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    if (this.valid_action(name, newData)) {\n      const edge: JssmTransition<mNT, mDT> = this.current_action_edge_for(name);\n      this._state = edge.to;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  transition(newState: mNT, newData?: mDT): boolean {\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    if (this.valid_transition(newState, newData)) {\n      this._state = newState;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  // can leave machine in inconsistent state.  generally do not use\n  force_transition(newState: mNT, newData?: mDT): boolean {\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    if (this.valid_force_transition(newState, newData)) {\n      this._state = newState;\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n\n\n  current_action_for(action: mNT): number | void {\n    const action_base: ?Map<mNT, number> = this._actions.get(action);\n    return action_base? action_base.get(this.state()): undefined;\n  }\n\n  current_action_edge_for(action: mNT): JssmTransition<mNT, mDT> {\n    const idx: ?number = this.current_action_for(action);\n    if ((idx === undefined) || (idx === null)) { throw new Error(`No such action ${JSON.stringify(action)}`); }\n    return this._edges[idx];\n  }\n\n  valid_action(action: mNT, _newData?: mDT): boolean {  // todo comeback unignore newData\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    return this.current_action_for(action) !== undefined;\n  }\n\n  valid_transition(newState: mNT, _newData?: mDT): boolean {  // todo comeback unignore newData\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    const transition_for: ?JssmTransition<mNT, mDT> = this.lookup_transition_for(this.state(), newState);\n\n    if (!(transition_for))          { return false; }\n    if (transition_for.forced_only) { return false; }\n\n    return true;\n\n  }\n\n  valid_force_transition(newState: mNT, _newData?: mDT): boolean {  // todo comeback unignore newData\n    // todo whargarbl implement hooks\n    // todo whargarbl implement data stuff\n    // todo major incomplete whargarbl comeback\n    return (this.lookup_transition_for(this.state(), newState) !== undefined);\n  }\n\n\n}\n\n\n\n\n\nfunction sm<mNT, mDT>(template_strings: Array<string> /* , arguments */): Machine<mNT, mDT> {\n\n    // foo`a${1}b${2}c` will come in as (['a','b','c'],1,2)\n    // this includes when a and c are empty strings\n    // therefore template_strings will always have one more el than template_args\n    // therefore map the smaller container and toss the last one on on the way out\n\n    return new Machine(make(template_strings.reduce(\n\n      // in general avoiding `arguments` is smart.  however with the template\n      // string notation, as designed, it's not really worth the hassle\n\n      /* eslint-disable fp/no-arguments */\n      /* eslint-disable prefer-rest-params */\n      (acc, val, idx): string => `${acc}${arguments[idx]}${val}`  // arguments[0] is never loaded, so args doesn't need to be gated\n      /* eslint-enable  prefer-rest-params */\n      /* eslint-enable  fp/no-arguments */\n\n    )));\n\n}\n\n\n\n\n\nexport {\n\n  version,\n\n  transfer_state_properties,\n\n  Machine,\n\n  make,\n    parse,\n    compile,\n\n  sm,\n\n  arrow_direction,\n  arrow_left_kind,\n  arrow_right_kind,\n\n  // todo whargarbl these should be exported to a utility library\n  seq, weighted_rand_select, histograph, weighted_sample_select, weighted_histo_key\n\n};\n"]} \ No newline at end of file diff --git a/src/js/jssm.js b/src/js/jssm.js index 4593cdcb..a3b7d6c3 100644 --- a/src/js/jssm.js +++ b/src/js/jssm.js @@ -180,8 +180,8 @@ function makeTransition( main_path : kind === 'main' }; - if ((wasList !== undefined) && (wasIndex === undefined)) { throw "Must have an index if transition was in a list"; } - if ((wasIndex !== undefined) && (wasList === undefined)) { throw "Must be in a list if transition has an index"; } + if ((wasList !== undefined) && (wasIndex === undefined)) { throw "Must have an index if transition was in a list"; } + if ((wasIndex !== undefined) && (wasList === undefined)) { throw "Must be in a list if transition has an index"; } /* if (typeof edge.to === 'object') { diff --git a/src/js/tests/cycles.js b/src/js/tests/cycles.js index f12194e1..25de4687 100644 --- a/src/js/tests/cycles.js +++ b/src/js/tests/cycles.js @@ -49,19 +49,23 @@ describe('cycle strategies', async _it => { describe('bidi basic cycle', async it => { - is_v('+1 <- [a b c] -> +1;', [{from: ['a','b','c'], key: 'transition', se: {kind: '->', to: {key: 'cycle', value: 1}}}], it); + is_v('+1 <- [a b c] -> +1;', [{from: {key: 'cycle', value: 1}, key: 'transition', se: {kind: '<-', se: {kind: '->', to: {key: 'cycle', value: 1}}, to: ['a','b','c']}}], it); }); describe('bidi negative cycle', async it => { - is_v('-1 <- [a b c] -> -1;', [{from: ['a','b','c'], key: 'transition', se: {kind: '->', to: {key: 'cycle', value: -1}}}], it); + is_v('-1 <- [a b c] -> -1;', [{from: {key: 'cycle', value: -1}, key: 'transition', se: {kind: '<-', se: {kind: '->', to: {key: 'cycle', value: -1}}, to: ['a','b','c']}}], it); + }); + + describe('bidi basic/negative cycle', async it => { + is_v('+1 <- [a b c] -> -1;', [{from: {key: 'cycle', value: 1}, key: 'transition', se: {kind: '<-', se: {kind: '->', to: {key: 'cycle', value: -1}}, to: ['a','b','c']}}], it); }); describe('bidi nullary cycle', async it => { - is_v('+0 <- [a b c] -> +0;', [{from: ['a','b','c'], key: 'transition', se: {kind: '->', to: {key: 'cycle', value: 0}}}], it); + is_v('+0 <- [a b c] -> +0;', [{from: {key: 'cycle', value: 0}, key: 'transition', se: {kind: '<-', se: {kind: '->', to: {key: 'cycle', value: 0}}, to: ['a','b','c']}}], it); }); describe('bidi wide cycle', async it => { - is_v('+2 <- [a b c] -> +2;', [{from: ['a','b','c'], key: 'transition', se: {kind: '->', to: {key: 'cycle', value: 2}}}], it); + is_v('+2 <- [a b c] -> -2;', [{from: {key: 'cycle', value: 2}, key: 'transition', se: {kind: '<-', se: {kind: '->', to: {key: 'cycle', value: -2}}, to: ['a','b','c']}}], it); }); /*