跳至主要內容

NodeFlow 列表语法

LincDocs大约 3 分钟

NodeFlow 列表语法

一种基于Markdown列表的便于输入的节点描述语法

新增一种能手写的格式,说真的有时设计语法比开发成就感还强……大家讨论讨论语法,看有没有什么可以优化的地方

  1. 该语法可以和AnyBlock插件配合,从列表进行声明
  2. 参考了:JSON、JSONL、YAML、Mermaid/Mehrmaid 流程图语法

示例

Plugin effect (插件效果)
Plugin effect (插件效果)

示例 - 结合anyblock

[code(nodeflow-list)]

- nodes
  - node1:重名测试
    - o1:重名测试, output
    - o2:重名测试, output
  - node2:重名测试
    - i, input
    - o, output
    - v, value
  - Group1
    - node3
      - i, input
      - i2, input
    - node4
- edges
  - node1,o1, node2,i
  - node2,o, node3,i
  - node2,o, node4,b

通用规则

  1. 一行一个项,“项” 有四种:节点、节点上I/O Socket或属性项、线、节点组,他们的声明方式:
    • 节点/组:id:name, type,不写冒号表示id和节点名是一样的,type可以不写,默认为 "node"
    • socket:id:name, type,type为input/output表述输入或输出节点,value表示节点的内部属性
    • 线:从哪个节点id,的哪个socket id,到哪个节点id,的哪个socket id
  2. 缩进关系表示包含关系。例如节点组可以包含节点,节点可以包含节点组

特殊规则 (进阶)

  1. 最外层是两个特殊组,nodes和edges,固定的。
    • 当然,有一个写法变形可以去掉最外层,用如果该项有四个参数就是edges组,否则则为nodes组,但我觉得虽然能写少了,但可能更容易造成混乱?待定
  2. 当不声明节点socket时,会默认声明四个隐藏节点:left、right、top、bottom

超简化

实际用例参考