TreeCode

Data Modelling and Programming for the Next Generation

Scroll below for more information.

deck @termsurf/base
  mark <0.0.1>
  head <A TreeCode Package Manager>
  term link-text
  term computation
  term philosophy
  term information
  term platform
  term white-label
  term compiler
  face <Lance Pollard>, site <foo@bar.com>
  task ./task
  read ./note
  lock apache-2
  sort tool
  link @termsurf/bolt, mark <0.x.x>
  link @termsurf/nest, mark <0.x.x>
  link @termsurf/crow, mark <0.x.x>

Prioritized for Humans and Machines

These trees of terms are probably the simplest and easiest trees of text to read and write which you could conjure up. Frameworks can be built around the trees to process them, link them together into networks, and allow them to be used for optimized computation. The resulting runtime structures can be finely tuned infinitely from there, resulting in clean code, readable data, and fast programs. By convention we put them in .tree files.

When taking notes in structured ways, TreeCode makes it practical and straightforward to quickly whip together intuitive Domain-Specific Languages (DSLs) of all shapes and kinds. It is also more powerful than pure JSON or YAML, because it can be thought of as code. It's all in how you leverage it to get the most power from it. It doesn't come with any bells and whistles, all of that can be found in tools built on top of this like NoteTree.

Thoughts Become Structured Knowledge

Compare TreeCode to the standard data formats JSON/XML/YAML/etc. It's more difficult to get and stay in the zone while writing things down in JSON than it could be.

deck @termsurf/base
  mark <0.0.1>
  head <A TreeCode Package Manager>
  term link-text
  term computation
  term philosophy
  term information
  term platform
  term white-label
  term compiler
  face <Lance Pollard>, site <foo@bar.com>
  task ./task
  read ./note
  lock apache-2
  sort tool
  link @termsurf/bolt, mark <0.x.x>
  link @termsurf/nest, mark <0.x.x>
  link @termsurf/crow, mark <0.x.x>
{
  "deck": {
    "name": "@termsurf/base",
    "mark": "0.0.1",
    "head": "A TreeCode Package Manager",
    "term": [
      "link-text",
      "computation",
      "philosophy",
      "information",
      "platform",
      "white-label",
      "compiler"
    ],
    "face": {
      "name": "Lance Pollard",
      "site": "foo@bar.com"
    },
    "task": "./task",
    "read": "./note",
    "lock": "apache-2",
    "sort": "tool",
    "link": [
      {
        "name": "@termsurf/bolt",
        "mark": "0.x.x"
      },
      {
        "name": "@termsurf/nest",
        "mark": "0.x.x"
      },
      {
        "name": "@termsurf/crow",
        "mark": "0.x.x"
      }
    ]
  }
}

However, it's not even accurate to render some of these as JSON or YAML, which are just keeping track of strings here. We can think of these as having imported values which are being bound to the tree structure. That is something a framework would tweeze out of your model and data definitions, using either a standard parser for common structures like functions and types, or you can make your own custom parser.

Workflow

With TreeCode and TreeCode alone, you don't have much. Just as you don't have much with JSON by itself. You can use the TreeCode parser to get a tree structure which is defined in the spec. Then you transform the tree structure according to the rules you lay out for that tree DSL/pattern, and compile it into data, code, or both. Check out NoteTree for the start on creating a coding/data framework on top of TreeCode. Still has a ways to go, but it will give you further ideas. And perhaps you can help us get it across the finish line!

Then, it's all about writing things down. First just go free form and write notes however you do, in Markdown, whatever. Then go back and find the data models in it, and create types, at least mentally. Then come up with the terms used to define the nests in the tree links, the anchor nodes so-to-speak, and then you are on your way to having a concise, clean way of capturing data of that form. That's the kind of thing we did to capture tons of vocabulary words into structured form, like these Cherokee words.

word <ᎠᎵᏍᏕᎸᏗ>
  sense <Accommodate>

word <ᎠᎵᎪᏁᏗ>
  sense <Accompany>

word <ᎠᏍᏆᏗᏍᏗ>
  sense <Accomplish>

We have the beginning outlines of tons of projects for collecting types and data on the GitHub org. Help make that happen, or start your own projects. The last step once you get your structured trees written down, is to parse and compile it, but that's where NoteTree is headed.

Hello World

Terms

These are all examples of terms and term trees.

xo
hello-world
foo-bar-baz
abc123
hello world
this is a tree
this
  is
    a
      tree

Numbers

add 1, 2
add 1, subtract -2, 3.14

Codes

i #b0101, am bits
i #o123, am octal
i #xaaaaaa, am hex

Strings

write <hello world>
text <
  This is a long paragraph.

  And this is another {type}.
>
moon <Cycles every {bold(<28 {period}s>)}.>

Paths

These are common strings which don't need brackets.

load @some/path
load ./relative/path.png
load /an-absolute/other/path.js
load **/*.js
hook /@:user

Comments

# comments are like ruby
# one per line

Frequently Asked Questions

Is TreeCode usable today?

Yes. TreeCode is usable today. The parser returns a detailed AST for the sytnax defined here, and from there you have to interpret the AST. See NoteTree for an example of interpreting TreeCode.

Why TreeCode?

Because TreeCode is the simplest possible way to write complex trees of data, simpler than JSON and YAML and XML. And because it is more robust, allowing for interpolation and interpretation. Finally, because it is easy for people to read and write, it lowers the barrier to entry, and potentially non-coders could contribute.

How about a robust TreeCode interpreter?

We are working on NoteTree, a programming framework built on top of the TreeCode syntax. It will take a lot more work, if it's a solo developer then at least a year working ful time. With help, we can speed that up.

How do you tell it how to interpret the tree I wrote?

In short, you define a grammar using the mine DSL from NoteTree, and then the compiler uses that grammar to compile your note tree to a structured object.

Take a Deeper Dive