define display function in C
This commit is contained in:
parent
1de4073212
commit
8a9bd366a1
|
@ -876,23 +876,6 @@
|
||||||
|
|
||||||
(export call-with-port)
|
(export call-with-port)
|
||||||
|
|
||||||
(define-library (scheme write)
|
|
||||||
(import (scheme base))
|
|
||||||
|
|
||||||
(define (display obj . opts)
|
|
||||||
(let ((port (if (null? opts) (current-output-port) (car opts))))
|
|
||||||
(cond
|
|
||||||
((string? obj)
|
|
||||||
(write-string obj port))
|
|
||||||
((char? obj)
|
|
||||||
(write-char obj port))
|
|
||||||
((symbol? obj)
|
|
||||||
(write-string (symbol->string obj) port))
|
|
||||||
(else
|
|
||||||
(write obj port)))))
|
|
||||||
|
|
||||||
(export display))
|
|
||||||
|
|
||||||
;;; Appendix A. Standard Libraries Lazy
|
;;; Appendix A. Standard Libraries Lazy
|
||||||
(define-library (scheme lazy)
|
(define-library (scheme lazy)
|
||||||
(import (scheme base)
|
(import (scheme base)
|
||||||
|
|
47
src/write.c
47
src/write.c
|
@ -45,19 +45,24 @@ is_quasiquote(pic_state *pic, pic_value pair)
|
||||||
struct writer_control {
|
struct writer_control {
|
||||||
pic_state *pic;
|
pic_state *pic;
|
||||||
xFILE *file;
|
xFILE *file;
|
||||||
|
int mode;
|
||||||
xhash *labels;
|
xhash *labels;
|
||||||
xhash *visited;
|
xhash *visited;
|
||||||
int cnt;
|
int cnt;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define WRITE_MODE 1
|
||||||
|
#define DISPLAY_MODE 2
|
||||||
|
|
||||||
static struct writer_control *
|
static struct writer_control *
|
||||||
writer_control_new(pic_state *pic, xFILE *file)
|
writer_control_new(pic_state *pic, xFILE *file, int mode)
|
||||||
{
|
{
|
||||||
struct writer_control *p;
|
struct writer_control *p;
|
||||||
|
|
||||||
p = (struct writer_control *)pic_alloc(pic, sizeof(struct writer_control));
|
p = (struct writer_control *)pic_alloc(pic, sizeof(struct writer_control));
|
||||||
p->pic = pic;
|
p->pic = pic;
|
||||||
p->file = file;
|
p->file = file;
|
||||||
|
p->mode = mode;
|
||||||
p->labels = xh_new_ptr();
|
p->labels = xh_new_ptr();
|
||||||
p->visited = xh_new_ptr();
|
p->visited = xh_new_ptr();
|
||||||
p->cnt = 0;
|
p->cnt = 0;
|
||||||
|
@ -228,6 +233,10 @@ write_core(struct writer_control *p, pic_value obj)
|
||||||
xfprintf(file, "%s", pic_symbol_name(pic, pic_sym(obj)));
|
xfprintf(file, "%s", pic_symbol_name(pic, pic_sym(obj)));
|
||||||
break;
|
break;
|
||||||
case PIC_TT_CHAR:
|
case PIC_TT_CHAR:
|
||||||
|
if (p->mode == DISPLAY_MODE) {
|
||||||
|
xfputc(pic_char(obj), file);
|
||||||
|
break;
|
||||||
|
}
|
||||||
switch (pic_char(obj)) {
|
switch (pic_char(obj)) {
|
||||||
default: xfprintf(file, "#\\%c", pic_char(obj)); break;
|
default: xfprintf(file, "#\\%c", pic_char(obj)); break;
|
||||||
case '\a': xfprintf(file, "#\\alarm"); break;
|
case '\a': xfprintf(file, "#\\alarm"); break;
|
||||||
|
@ -259,6 +268,10 @@ write_core(struct writer_control *p, pic_value obj)
|
||||||
xfprintf(file, "#<port %p>", pic_ptr(obj));
|
xfprintf(file, "#<port %p>", pic_ptr(obj));
|
||||||
break;
|
break;
|
||||||
case PIC_TT_STRING:
|
case PIC_TT_STRING:
|
||||||
|
if (p->mode == DISPLAY_MODE) {
|
||||||
|
xfprintf(file, "%s", pic_str_cstr(pic_str_ptr(obj)));
|
||||||
|
break;
|
||||||
|
}
|
||||||
xfprintf(file, "\"");
|
xfprintf(file, "\"");
|
||||||
write_str(pic, pic_str_ptr(obj), file);
|
write_str(pic, pic_str_ptr(obj), file);
|
||||||
xfprintf(file, "\"");
|
xfprintf(file, "\"");
|
||||||
|
@ -320,7 +333,7 @@ write(pic_state *pic, pic_value obj, xFILE *file)
|
||||||
{
|
{
|
||||||
struct writer_control *p;
|
struct writer_control *p;
|
||||||
|
|
||||||
p = writer_control_new(pic, file);
|
p = writer_control_new(pic, file, WRITE_MODE);
|
||||||
|
|
||||||
traverse_shared(p, obj); /* FIXME */
|
traverse_shared(p, obj); /* FIXME */
|
||||||
|
|
||||||
|
@ -334,7 +347,7 @@ write_simple(pic_state *pic, pic_value obj, xFILE *file)
|
||||||
{
|
{
|
||||||
struct writer_control *p;
|
struct writer_control *p;
|
||||||
|
|
||||||
p = writer_control_new(pic, file);
|
p = writer_control_new(pic, file, WRITE_MODE);
|
||||||
|
|
||||||
/* no traverse here! */
|
/* no traverse here! */
|
||||||
|
|
||||||
|
@ -348,7 +361,7 @@ write_shared(pic_state *pic, pic_value obj, xFILE *file)
|
||||||
{
|
{
|
||||||
struct writer_control *p;
|
struct writer_control *p;
|
||||||
|
|
||||||
p = writer_control_new(pic, file);
|
p = writer_control_new(pic, file, WRITE_MODE);
|
||||||
|
|
||||||
traverse_shared(p, obj);
|
traverse_shared(p, obj);
|
||||||
|
|
||||||
|
@ -357,6 +370,20 @@ write_shared(pic_state *pic, pic_value obj, xFILE *file)
|
||||||
writer_control_destroy(p);
|
writer_control_destroy(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
display(pic_state *pic, pic_value obj, xFILE *file)
|
||||||
|
{
|
||||||
|
struct writer_control *p;
|
||||||
|
|
||||||
|
p = writer_control_new(pic, file, DISPLAY_MODE);
|
||||||
|
|
||||||
|
traverse_shared(p, obj); /* FIXME */
|
||||||
|
|
||||||
|
write_core(p, obj);
|
||||||
|
|
||||||
|
writer_control_destroy(p);
|
||||||
|
}
|
||||||
|
|
||||||
pic_value
|
pic_value
|
||||||
pic_debug(pic_state *pic, pic_value obj)
|
pic_debug(pic_state *pic, pic_value obj)
|
||||||
{
|
{
|
||||||
|
@ -420,6 +447,17 @@ pic_write_write_shared(pic_state *pic)
|
||||||
return pic_none_value();
|
return pic_none_value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static pic_value
|
||||||
|
pic_write_display(pic_state *pic)
|
||||||
|
{
|
||||||
|
pic_value v;
|
||||||
|
struct pic_port *port = pic_stdout(pic);
|
||||||
|
|
||||||
|
pic_get_args(pic, "o|p", &v, &port);
|
||||||
|
display(pic, v, port->file);
|
||||||
|
return pic_none_value();
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
pic_init_write(pic_state *pic)
|
pic_init_write(pic_state *pic)
|
||||||
{
|
{
|
||||||
|
@ -427,5 +465,6 @@ pic_init_write(pic_state *pic)
|
||||||
pic_defun(pic, "write", pic_write_write);
|
pic_defun(pic, "write", pic_write_write);
|
||||||
pic_defun(pic, "write-simple", pic_write_write_simple);
|
pic_defun(pic, "write-simple", pic_write_write_simple);
|
||||||
pic_defun(pic, "write-shared", pic_write_write_shared);
|
pic_defun(pic, "write-shared", pic_write_write_shared);
|
||||||
|
pic_defun(pic, "display", pic_write_display);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue