summaryrefslogtreecommitdiffstats
path: root/termios.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2022-02-19 08:52:59 -0800
committerKaz Kylheku <kaz@kylheku.com>2022-02-19 08:52:59 -0800
commitcaf46a07285ce2b214fdfce1b2af3375966c52f9 (patch)
treeedd6620d7e47e331a71e4630a55b49e9e55c50b6 /termios.c
parent834ebaf314521b9b61a2e9f0f3f3afa8b16990bb (diff)
downloadtxr-caf46a07285ce2b214fdfce1b2af3375966c52f9.tar.gz
txr-caf46a07285ce2b214fdfce1b2af3375966c52f9.tar.bz2
txr-caf46a07285ce2b214fdfce1b2af3375966c52f9.zip
autoload: move termios material into termios module.
* autoload.c (termios_set_entries, termios_instantiate): Static functions removed from here. (autoload_init): autoload_reg call for above functions removed from here. * termios.c (termios_set_entries, termios_instantiate): Static functions moved here. (termios_init): autoload_reg call moved here.
Diffstat (limited to 'termios.c')
-rw-r--r--termios.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/termios.c b/termios.c
index e5f359c9..818eea47 100644
--- a/termios.c
+++ b/termios.c
@@ -46,6 +46,8 @@
#include "stream.h"
#include "struct.h"
#include "sysif.h"
+#include "txr.h"
+#include "autoload.h"
#include "termios.h"
val termios_s, iflag_s, oflag_s, cflag_s, lflag_s, cc_s, ispeed_s, ospeed_s;
@@ -371,6 +373,24 @@ static val decode_speeds(val termios)
return termios;
}
+static val termios_set_entries(val fun)
+{
+ val slname[] = {
+ lit("set-iflags"), lit("set-oflags"), lit("set-cflags"), lit("set-lflags"),
+ lit("clear-iflags"), lit("clear-oflags"), lit("clear-cflags"), lit("clear-lflags"),
+ lit("go-raw"), lit("go-cbreak"), lit("go-canon"),
+ lit("string-encode"), lit("string-decode"), nil
+ };
+ autoload_set(al_slot, slname, fun);
+ return nil;
+}
+
+static val termios_instantiate(void)
+{
+ load(scat2(stdlib_path, lit("termios")));
+ return nil;
+}
+
void termios_init(void)
{
val termios_t;
@@ -583,4 +603,6 @@ void termios_init(void)
reg_varl(intern(lit("tcsanow"), user_package), num_fast(TCSANOW));
reg_varl(intern(lit("tcsadrain"), user_package), num_fast(TCSADRAIN));
reg_varl(intern(lit("tcsaflush"), user_package), num_fast(TCSAFLUSH));
+
+ autoload_reg(termios_instantiate, termios_set_entries);
}