all repos — hex @ bf132c89d800c4ad4a435aeaef5656e72f6a6971

A tiny, minimalist, slightly-esoteric concatenative programming lannguage.

web/contents/home.html

 1
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
<article>
    <h2>Welcome to the <em>hex</em> programming language</h2>
    <p><strong>hex</strong> is a tiny, minimalist, concatenative, stack-based and slightly-esoteric programming language
        that can run on many platforms (including <a href="/play">the browser</a>) and can be used as an embedded
        language, to create shell scripts, or simply to learn more about concatenative programming.</p>
    <p>Its syntax is heavily inspired by the <a href="https://min-lang.org" target="_blank">min</a> programming
        language, and features
        space-separated tokens, no unnecessary punctuation characters, and round brackets to delimit lists.</p>
    <h2>Features</h2>
    <ul>
        <li>Support <strong>32bit integers</strong>, <em>written only in hexadecimal format</em>, both positive and
            negative (represented via <a href="https://en.wikipedia.org/wiki/Two%27s_complement" target="_blank">two's
                complement</a>),
            <strong>strings</strong>, and <strong>quotations</strong> (lists).
        </li>
        <li><strong>64 native symbols</strong> implementing simple arithmetic, boolean logic, bitwise operations,
            comparison of integers, read/write from/to stdin/stdout/stderr, read and write files, execute external
            processes, work with quotations and strings, create and delete user symbols (variables), error handling, and
            manipulate the stack.</li>
        <li>Fully <strong>homoiconic</strong> (everything is data).</li>
        <li>Includes a simple <strong>REPL</strong>.</li>
        <li>Includes an integrated <strong>help system</strong>.</li>
        <li>Implemented as <strong>a single <a href="https://github.com/h3rald/hex/blob/master/hex.c" target="_blank">.c
                    file</a> and a
                single <a href="https://github.com/h3rald/hex/blob/master/hex.h" target="_blank">.h file</a></strong>,
            making it easier
            to
            embed in other programs and port to different platforms.</li>
    </ul>
    <h2>Example</h2>
    <p> The following code executes the <em>ls</em> command, retrieves the files returned in standard output, and stores
        them
        inside a quotation that is then printed:</p>
    <pre><code>"ls" run 0x1 get "&bsol;n" split puts</code></pre>
    <p>Note that <strong>no variable is used in the code above</strong>! Let's break it down:</p>
    <ul>
        <li>The string <code>ls</code> is pushed on the stack.</li>
        <li>The <code>run</code> symbol is executed, which runs the command <code>ls</code> and pushes quotation on the
            stack
            containing three elements: the return code of the program, its standard output, and its standard error.</li>
        <li>The integer <code>0x1</code> is pushed on the stack.</li>
        <li>The <code>get</code> symbol is executed, which retrieves the second element of the quotation (the standard
            output).</li>
        <li>The string <code>&bsol;n</code> is pushed on the stack.</li>
        <li>The <code>split</code> symbol is executed, which splits the string using the newline character as a
            separator.</li>
        <li>The <code>puts</code> symbol is executed, which prints the quotation on the stack.</li>
    </ul>
</article>