Skip to main content

bare-script

Project description

bare-script

PyPI - Status PyPI GitHub PyPI - Python Version

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

# Parse the script
script = parse_script('''\
# Double a number
function double(n):
    return n * 2
endfunction

return N + ' times 2 is ' + double(N)
''')

# Execute the script
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

# Parse the script
script = parse_script('''\
# Fetch the BareScript builtin library documentation JSON
docs = jsonParse(systemFetch('https://craigahobbs.github.io/bare-script-py/library/library-builtin.json'))

# Return the number of builtin functions
return 'The BareScript Library has ' + arrayLength(objectGet(docs, 'functions')) + ' builtin functions'
''')

# Execute the script
print(execute_script(script, {'fetchFn': fetch_http}))

This outputs:

The BareScript Library has 108 builtin 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

# Parse the expression
expr = parse_expression('2 * max(a, b, c)')

# Evaluate the expression
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. The MarkdownUp runtime contains 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!')
```

C Runtime

The package ships with an optional CPython C extension, runtime_c, that mirrors the pure-Python runtime for faster script execution. The compiled extension is used automatically when available; set the environment variable BARESCRIPT_RUNTIME_PY=1 to force the pure-Python runtime.

The extension supports CPython 3.10 and later on both the default (GIL) and free-threaded Python builds.

The C runtime runs the BareScript include library test suite (make test-include) about 3.6x faster than the pure-Python runtime (CPython 3.14, Apple M-series):

Runtime Test Suite Time (ms) Multiple
BareScript (C) 586 1.0x
BareScript (Python) 2115 3.6x

Compute-intensive scripts run up to roughly 30x faster - for example, the Mandelbrot benchmark (make perf), shown here against the equivalent native Python program:

Language Best Time (ms) Multiple
Python 152 1.0x
BareScript (C) 322 2.1x
BareScript (Python) 10389 68.5x

Using BareScript with an AI Assistant

This repository ships a SKILL.md file that teaches an AI coding assistant how to write idiomatic BareScript — language syntax, the built-in and include libraries, the MarkdownUp application pattern, and the unit-test conventions. It is plain Markdown and applies to either BareScript implementation.

For Claude Code and other tools that follow the Agent Skills convention, install it as a project or user skill:

mkdir -p .claude/skills/bare-script
cp SKILL.md .claude/skills/bare-script/SKILL.md

Use ~/.claude/skills/bare-script/SKILL.md instead to make it available across all projects. For other assistants, include the file's contents in your system prompt or rules file.

Once installed, prompt the assistant with a task like:

claude "Build a MarkdownUp application that plays tic-tac-toe against the user, with a reset button and a running win/loss/draw tally rendered as a bar chart. Save it as ticTacToe.md"

To run the resulting MarkdownUp application locally, install the markdown-up viewer and point it at the Markdown file:

pip install markdown-up
markdown-up ticTacToe.md

The BareScript library is also documented as single-page Markdown, which can be fetched directly into an assistant's context alongside SKILL.md:

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'

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bare_script-4.2.7.tar.gz (151.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bare_script-4.2.7-cp314-cp314-macosx_26_0_arm64.whl (159.7 kB view details)

Uploaded CPython 3.14macOS 26.0+ ARM64

File details

Details for the file bare_script-4.2.7.tar.gz.

File metadata

  • Download URL: bare_script-4.2.7.tar.gz
  • Upload date:
  • Size: 151.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for bare_script-4.2.7.tar.gz
Algorithm Hash digest
SHA256 59730e49356e039bd8cca9e1e9028a9e003e1096ab35e007f72feab4e2d2cecc
MD5 201a29e107e93af2ebe60d6181675941
BLAKE2b-256 fc78948bd4e945f8fdba17cedcca73b2ffaff8575233284080c73795fc2c947b

See more details on using hashes here.

File details

Details for the file bare_script-4.2.7-cp314-cp314-macosx_26_0_arm64.whl.

File metadata

File hashes

Hashes for bare_script-4.2.7-cp314-cp314-macosx_26_0_arm64.whl
Algorithm Hash digest
SHA256 690c454fb84857628cd380bac056c3023ee91540ca9f141e9d0017949ae91f7d
MD5 d1921118f6858388a1afad64d8779716
BLAKE2b-256 2eecbf921622314c982aef63b72396b866ad2e783c4f35c4a6dba1735fdeee19

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page