The Nomsu programming language. https://nomsu.org
Go to file
2018-01-19 17:32:01 -08:00
examples Updated examples and made operator characters not stick to each other. 2018-01-03 19:26:41 -08:00
lib Updated class.nom for new syntax. 2018-01-19 17:32:01 -08:00
.gitignore Added scratch folder to .gitignore 2018-01-19 17:28:47 -08:00
compile_lib.sh Added compile step for lib/core.nom 2018-01-16 01:45:43 -08:00
consolecolors.lua Improved documentation and compile script. 2017-12-18 16:45:46 -08:00
LICENSE Added license. 2017-10-09 04:09:06 -07:00
nomsu.lua Added scratch folder to .gitignore 2018-01-19 17:28:47 -08:00
nomsu.moon Refactored syntax a bit so that ":" isn't necessary for a block, and can 2018-01-19 17:30:39 -08:00
nomsu.peg Refactored syntax a bit so that ":" isn't necessary for a block, and can 2018-01-19 17:30:39 -08:00
README.md Formatting. 2017-10-09 05:24:17 -07:00
utils.lua Initial commit of object oriented classes. 2018-01-18 01:49:27 -08:00
uuid.lua Added "%'s id" to use UUIDs and changed "% = %" to "set % = %" and some 2018-01-11 03:32:12 -08:00

Nomsu

Nomsu (named after Nomic, and its creator, Peter Suber) is a programming language designed to be used for playing games of Nomic, or engaging in other similar activities revolving around natural language rule-making and self modification.

Dependencies

Nomsu's only dependencies are Lua (tested with version 5.2.4) (or Luajit (tested with version 2.1.0)) and LPEG (luarocks install lpeg). Nomsu's compiler was written in Moonscript, but all of the .moon files have been compiled into lua for convenience, so Moonscript is not a dependency.

Usage

  • To get a nomsu REPL, simply run lua nomsu.lua.
  • To run a .nom file with nomsu code, run lua nomsu.lua your_file.nom. Or lua nomsu.lua - if reading from stdin.
  • (Advanced/optional) To precompile a .nom file into lua, either run lua nomsu.lua your_file.nom -o output_file.lua or simply lua nomsu.lua -c your_file.nom (which will default to outputting to your_file.nom.lua). It is not necessary to precompile .nom files, but it can speed things up if it's a file that gets loaded by require "your_file.nom" a lot. require % can either take a .nom file (it will automatically look for a .nom.lua precompiled version), or a .lua file.
  • More usage options are avilable via lua nomsu.lua --help.

Layout

  • nomsu.moon/nomsu.lua - The nomsu compiler. The compiler is written in Moonscript, but a lua version of the file is provided in this repository for convenience.
  • utils.moon/utils.lua - A set of utility functions used by nomsu.moon. A lua version of this is also provided for convenience.
  • consolecolors.lua - Lua module that defines ANSI color codes for colored console output (used internally in nomsu.moon).
  • examples/how_do_i.nom - A simple walkthrough of some of the features of nomsu, written in nomsu. This is a good place to start.
  • examples/sample_code.nom - Some additional sample nomsu code.
  • examples/sample_game.nom - A sample game of Nomic, written in nomsu.
  • lib/collections.nom - Core library definitions related to collections, like lists and dictionaries.
  • lib/control_flow.nom - Core library definitions related to control flow, like if statements and for loops.
  • lib/core.nom - Core library file that loads other core library files. Files are loaded in dependency order.
  • lib/metaprogramming.nom - Core library essential functionality for metaprogramming, including macros to define macros, rules to define rules, and so on. This is where the language pulls itself up by its hair out the swamps of nothingness.
  • lib/moonscript.nom - Core library definitions for writing in moonscript. This is optional, and requires Lua's "moon" package.
  • lib/operators.nom - Core library definitions for operators like = and +.
  • lib/permissions.nom - Core library definitions for rules that modify the permission levels of rules.
  • lib/plurals.nom - Core library modulre that defines some simple rules to facilitate pluralizing and singularizing words. This is a bit frivolous, but can be useful for natural language.
  • lib/secrets.nom - Core library module that allows for closure-like behavior in nomsu for hiding data within rule definitions that can't be accessed elsewhere.
  • lib/testing.nom - Core library definitions for some testing facilities.
  • lib/utils.nom - Core library definitions of common utility functions, like sum of % and sqrt %.
  • compile_lib.sh - script to precompile lib/*.nom so they can be loaded faster. This is optional.

Extra

There is a vim plugin for the language available in the Vim Nomsu repository.