/* -*-comment-start: "//";comment-end:""-*- * GNU Mes --- Maxwell Equations of Software * Copyright © 2016,2017,2018 Jan (janneke) Nieuwenhuizen * * This file is part of GNU Mes. * * GNU Mes is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or (at * your option) any later version. * * GNU Mes 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with GNU Mes. If not, see . */ int g_depth; SCM fdisplay_ (SCM, int, int); SCM display_helper (SCM x, int cont, char* sep, int fd, int write_p) { fdputs (sep, fd); if (g_depth == 0) return cell_unspecified; g_depth = g_depth - 1; int t = TYPE (x); if (t == TCHAR) { if (!write_p) fdputc (VALUE (x), fd); else { fdputs ("#\\", fd); long v = VALUE (x); if (v == '\0') fdputs ("nul", fd); else if (v == '\a') fdputs ("alarm", fd); else if (v == '\b') fdputs ("backspace", fd); else if (v == '\t') fdputs ("tab", fd); else if (v == '\n') fdputs ("newline", fd); else if (v == '\v') fdputs ("vtab", fd); else if (v == '\f') fdputs ("page", fd); //Nyacc bug // else if (v == '\r') fdputs ("return", fd); else if (v == 13) fdputs ("return", fd); else if (v == ' ') fdputs ("space", fd); else fdputc (VALUE (x), fd); } } else if (t == TCLOSURE) { fdputs ("#", fd); } else if (t == TFUNCTION) { fdputs ("#", fd); } else if (t == TMACRO) { fdputs ("#", fd); } else if (t == TVARIABLE) { fdputs ("#", fd); } else if (t == TNUMBER) { fdputs (itoa (VALUE (x)), fd); } else if (t == TPAIR) { if (!cont) fdputs ("(", fd); if (CAR (x) == cell_circular && CADR (x) != cell_closure) { fdputs ("(*circ* . ", fd); int i = 0; x = CDR (x); while (x != cell_nil && i++ < 10) { fdisplay_ (CAAR (x), fd, write_p); fdputs (" ", fd); x = CDR (x); } fdputs (" ...)", fd); } else { if (x && x != cell_nil) fdisplay_ (CAR (x), fd, write_p); if (CDR (x) && TYPE (CDR (x)) == TPAIR) display_helper (CDR (x), 1, " ", fd, write_p); else if (CDR (x) && CDR (x) != cell_nil) { if (TYPE (CDR (x)) != TPAIR) fdputs (" . ", fd); fdisplay_ (CDR (x), fd, write_p); } } if (!cont) fdputs (")", fd); } else if (t == TKEYWORD || t == TPORT || t == TSPECIAL || t == TSTRING || t == TSYMBOL) { if (TYPE (x) == TPORT) { fdputs ("#", fd); } else if (t == TVECTOR) { fdputs ("#(", fd); SCM t = CAR (x); for (long i = 0; i < LENGTH (x); i++) { if (i) fdputc (' ', fd); fdisplay_ (VECTOR (x) + i, fd, write_p); } fdputc (')', fd); } else { fdputs ("<", fd); fdputs (itoa (TYPE (x)), fd); fdputs (":", fd); fdputs (itoa (x), fd); fdputs (">", fd); } return 0; } SCM display_ (SCM x) { g_depth = 5; return display_helper (x, 0, "", g_stdout, 0); } SCM display_error_ (SCM x) { g_depth = 5; return display_helper (x, 0, "", STDERR, 0); } SCM display_port_ (SCM x, SCM p) { assert (TYPE (p) == TNUMBER); return fdisplay_ (x, VALUE (p), 0); } SCM write_ (SCM x) { g_depth = 5; return display_helper (x, 0, "", g_stdout, 1); } SCM write_error_ (SCM x) { g_depth = 5; return display_helper (x, 0, "", STDERR, 1); } SCM write_port_ (SCM x, SCM p) { assert (TYPE (p) == TNUMBER); return fdisplay_ (x, VALUE (p), 1); } SCM fdisplay_ (SCM x, int fd, int write_p) ///((internal)) { g_depth = 5; return display_helper (x, 0, "", fd, write_p); } SCM exit_ (SCM x) ///((name . "exit")) { assert (TYPE (x) == TNUMBER); exit (VALUE (x)); } SCM xassq (SCM x, SCM a) ///for speed in core only { while (a != cell_nil && x != CDAR (a)) a = CDR (a); return a != cell_nil ? CAR (a) : cell_f; } SCM memq (SCM x, SCM a) { int t = TYPE (x); if (t == TCHAR || t == TNUMBER) { SCM v = VALUE (x); while (a != cell_nil && v != VALUE (CAR (a))) a = CDR (a); } else if (t == TKEYWORD) { SCM v = STRING (x); while (a != cell_nil && v != STRING (CAR (a))) a = CDR (a); } else while (a != cell_nil && x != CAR (a)) a = CDR (a); return a != cell_nil ? a : cell_f; } SCM equal2_p (SCM a, SCM b) { equal2: if (a == b) return cell_t; if (TYPE (a) == TPAIR && TYPE (b) == TPAIR) { if (equal2_p (CAR (a), CAR (b)) == cell_t) { a = CDR (a); b = CDR (b); goto equal2; } return cell_f; } if (TYPE (a) == TSTRING && TYPE (b) == TSTRING) { a = STRING (a); b = STRING (b); goto equal2; } if (TYPE (a) == TVECTOR && TYPE (b) == TVECTOR) { if (LENGTH (a) != LENGTH (b)) return cell_f; for (long i=0; i < LENGTH (a); i++) { SCM ai = VECTOR (a) + i; SCM bi = VECTOR (b) + i; if (TYPE (ai) == TREF) ai = REF (ai); if (TYPE (bi) == TREF) bi = REF (bi); if (equal2_p (ai, bi) == cell_f) return cell_f; } return cell_t; } return eq_p (a, b); } SCM last_pair (SCM x) { while (x != cell_nil && CDR (x) != cell_nil) x = CDR (x); return x; }