aboutsummaryrefslogtreecommitdiffstats
path: root/source/core.hpp
blob: 4e4c1e600d1cb65c54c549fda12a4a1b54f95d21 (plain)
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
50
51
52
53
54
// sprit-forth: A portable subroutine-threaded Forth.
// Copyright (C) 2023  Clyne Sullivan <clyne@bitgloo.com>
//
// This library is free software; you can redistribute it and/or modify it
// under the terms of the GNU Library General Public License as published by
// the Free Software Foundation; either version 2 of the License, or (at your
// option) any later version.
//
// This library is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
// FOR A PARTICULAR PURPOSE.  See the GNU Library General Public License for
// more details.
//
// You should have received a copy of the GNU Library General Public License
// along with this library; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin St, Fifth Floor, Boston, MA  02110-1301, USA.

#ifndef CORE_HPP
#define CORE_HPP

#include "types.hpp"

/**
 * To be implemented by the user: Adds available input to the source buffer.
 * @see addkey(int k)
 */
extern void getinput();

/**
 * "Function exit" word, analagous to a function's return statement.
 */
constexpr auto fexit = WordWrap<[] {
    extern FuncList IP;
    extern Cell rpop();
    IP = reinterpret_cast<FuncList>(rpop());
}>();

void jump(FuncList ip); /** Jumps to the given instruction pointer. */
void compileliteral();  /** Compiles LITERAL into the current definition. */

bool haskey();      /** Returns true if the source buffer is not empty. */
void addkey(int k); /** Adds the given character to the source buffer. */
int key();          /** Gets the next key available from the source buffer. */

Cell *comma(Cell n);     /** Stores `n` to HERE++, returns `n`'s storage. */
Addr aligned(Addr addr); /** Aligns the given address and returns it. */
void align(); /** Aligns HERE to the next Cell boundary. */
void word();  /** Definition of WORD. */
void colon(); /** Begins definition of a new word. */
void semic(); /** Ends the current word definition which becomes new LATEST. */
void tick();  /** Gets the execution token for the source buffer's next word. */

#endif // CORE_HPP