bare-script

BareScript
is a simple, lightweight, and portable programming language. Its Pythonic syntax is influenced by
JavaScript, C, and the Unix Shell. BareScript also has a library of built-in functions for common
programming operations. BareScript can be embedded within applications or used as a stand-alone
programming language using the command-line interface.
There are two implementations of BareScript:
BareScript for Python
(this package) and
BareScript for JavaScript.
Both implementations have 100% unit test coverage with identical unit test suites, so you can be
confident that BareScript will execute the same regardless of the underlying runtime environment.
Links
Executing BareScript Scripts
To execute a BareScript script, parse the script using the
parse_script
function. Then execute the script using the
execute_script
function. For example:
from bare_script import execute_script, parse_script
script = parse_script('''\
# Double a number
function double(n):
return n * 2
endfunction
return N + ' times 2 is ' + double(N)
''')
globals = {'N': 10}
print(execute_script(script, {'globals': globals}))
This outputs:
10 times 2 is 20
The BareScript Library
The BareScript Library
includes a set of built-in functions for mathematical operations, object manipulation, array
manipulation, regular expressions, HTTP fetch and more. The following example demonstrates the use
of the
systemFetch,
objectGet, and
arrayLength
functions.
import urllib.request
from bare_script import execute_script, fetch_http, parse_script
script = parse_script('''\
# Fetch the BareScript library documentation JSON
docs = jsonParse(systemFetch('https://craigahobbs.github.io/bare-script-py/library/library.json'))
# Return the number of library functions
return 'The BareScript Library has ' + arrayLength(objectGet(docs, 'functions')) + ' functions'
''')
print(execute_script(script, {'fetchFn': fetch_http}))
This outputs:
The BareScript Library has 105 functions
Evaluating BareScript Expressions
To evaluate a
BareScript expression,
parse the expression using the
parse_expression
function. Then evaluate the expression using the
evaluate_expression
function.
Expression evaluation includes the
BareScript Expression Library,
a set of built-in, spreadsheet-like functions.
For example:
from bare_script import evaluate_expression, parse_expression
expr = parse_expression('2 * max(a, b, c)')
variables = {'a': 1, 'b': 2, 'c': 3}
print(evaluate_expression(expr, None, variables))
This outputs:
6
The BareScript Command-Line Interface (CLI)
You can run BareScript from the command line using the BareScript CLI, "bare". BareScript script
files use the ".bare" file extension.
bare script.bare
Note: In the BareScript CLI, import statements and the
systemFetch
function read non-URL paths from the local file system.
systemFetch
calls with a non-URL path and a
request body
write the body to the path.
MarkdownUp, a Markdown Viewer with BareScript
MarkdownUp
is a Markdown Viewer that executes BareScript embedded within Markdown documents.
MarkdownUp includes the
MarkdownUp Library,
which extends the
BareScript Library
with functions for dynamically rendering Markdown text, drawing SVG images, etc.
For example:
# Markdown Application
This is a Markdown document with embedded BareScript:
~~~ markdown-script
markdownPrint('Hello, Markdown!')
~~~
Development
This package is developed using python-build.
It was started using python-template as follows:
template-specialize python-template/template/ bare-script-py/ -k package bare-script -k name 'Craig A. Hobbs' -k email 'craigahobbs@gmail.com' -k github 'craigahobbs'