@cicada-lang/cicada-whereabouts v0.1.10
Cicada Whereabouts
Logic programming with JSON.
In the sense that the syntax is close to JavaScript, and the query outputs are JSON lines.
I asked the boy beneath the pines. He said, "The master's gone alone Herb-picking, somewhere on the mount, Cloud-hidden, whereabouts unknown." -- Jia Dao
Install
npm install -g @cicada-lang/cicada-whereaboutsThe command line program is called whereabouts:
Example usage:
whereabouts docs/tests/clause-and-effect/worksheet-02-drinking-pairs.cwOutputs:
{ "success": true, "count": 3, "solutions": [{ "left": "mary" }, { "left": "john" }, { "left": "fred" }] }
{ "success": true, "count": 9, "solutions": [{ "left": "mary", "right": "mary" }, { "left": "mary", "right": "john" }, { "left": "mary", "right": "fred" }, { "left": "john", "right": "mary" }, { "left": "john", "right": "john" }, { "left": "john", "right": "fred" }, { "left": "fred", "right": "mary" }, { "left": "fred", "right": "john" }, { "left": "fred", "right": "fred" }] }
{ "success": true, "count": 14, "solutions": [{ "left": "john", "right": "john", "alcohol": "martini" }, { "left": "mary", "right": "mary", "alcohol": "gin" }, { "left": "mary", "right": "john", "alcohol": "gin" }, { "left": "mary", "right": "fred", "alcohol": "gin" }, { "left": "susan", "right": "susan", "alcohol": "vodka" }, { "left": "susan", "right": "fred", "alcohol": "vodka" }, { "left": "john", "right": "mary", "alcohol": "gin" }, { "left": "john", "right": "john", "alcohol": "gin" }, { "left": "john", "right": "fred", "alcohol": "gin" }, { "left": "fred", "right": "mary", "alcohol": "gin" }, { "left": "fred", "right": "john", "alcohol": "gin" }, { "left": "fred", "right": "fred", "alcohol": "gin" }, { "left": "fred", "right": "susan", "alcohol": "vodka" }, { "left": "fred", "right": "fred", "alcohol": "vodka" }] }The outputs are JSON lines, You can also make use of jq to format them:
whereabouts docs/tests/clause-and-effect/worksheet-02-drinking-pairs.cw | jqThe content of worksheet-02-drinking-pairs.cw is:
Drink { person: "john", alcohol: "martini" }
Drink { person: "mary", alcohol: "gin" }
Drink { person: "susan", alcohol: "vodka" }
Drink { person: "john", alcohol: "gin" }
Drink { person: "fred", alcohol: "gin" }
Drink { person: "fred", alcohol: "vodka" }
Friends { left, right, alcohol }
------------------------------------ {
  Drink { person: left, alcohol }
  Drink { person: right, alcohol }
}
query (left) {
  Friends { left, right: "mary", alcohol: "gin" }
}The above example use JSON object, we can also use JSON array.
Like in worksheet-03-affordable-journeys.cw:
Border ["sussex", "kent"]
Border ["sussex", "surrey"]
Border ["surrey", "kent"]
Border ["hampshire", "sussex"]
Border ["hampshire", "surrey"]
Border ["hampshire", "berkshire"]
Border ["berkshire", "surrey"]
Border ["wiltshire", "hampshire"]
Border ["wiltshire", "berkshire"]
Adjacent [x, y]
---------------- border {
  Border [x, y]
}
Adjacent [x, y]
---------------- symmetry {
  Border [y, x]
}
Affordable [x, y]
-------------------- {
  Adjacent [x, z]
  Adjacent [z, y]
}
query (to_kent) {
  Affordable [to_kent, "kent"]
}Please see docs/tests for more examples.
Development
npm install           # Install dependencies
npm run build         # Compile `src/` to `lib/`
npm run build:watch   # Watch the compilation
npm run format        # Format the code
npm run test          # Run test
npm run test:watch    # Watch the testingContributions
To make a contribution, fork this project and create a pull request.
Please read the STYLE-GUIDE.md before you change the code.
Remember to add yourself to AUTHORS. Your line belongs to you, you can write a little introduction to yourself but not too long.
It is assumed that all non draft PRs are ready to be merged. If your PR is not ready to be merged yet, please make it a draft PR:
During the development of your PR, you can make use of the TODO.md file to record ideas temporarily, and this file should be clean again at the end of your development.