我试图用Common编写一个动态创建其他Lisp文件的程序。通用Lisp的print函数似乎对此非常有用。不幸的是,函数只在一行上输出数据。例如(只打印到标准输出):
(print '(let ((a 1) (b 2) (c 3)) (+ a b c)))
>> (let ((a 1) (b 2) (c 3)) (+ a b c))生成的lisp文件需要是人类可读的,因此不应该最小化空白。pprint函数似乎是解决我的问题的方法。由于为真,函数应该打印在多行。换言之:
(pprint '(let ((a 1) (b 2) (c 3)) (+ a b c)))
>> (let ((a 1)
>> (b 2)
>> (c 3))
>> (+ a b c))然而,在快板CL中,pprint的行为似乎与打印方式相同。输出仅在一行上。有没有办法使函数以“漂亮”的方式打印s-表达式?在正确打印函数之前,是否还需要设置其他全局值?是否有可供选择的函数/宏?谢谢你的帮助!
发布于 2014-06-18 21:37:34
漂亮的打印机控制的不仅仅是*打印-漂亮*。例如,查看SBCL中与*的交互作用(在SLIME下):
CL-USER> (pprint '(let ((a 1) (b 2) (c 3)) (+ a b c)))
(LET ((A 1) (B 2) (C 3))
(+ A B C))
; No value
CL-USER> (let ((*print-right-margin* 10))
(pprint '(let ((a 1) (b 2) (c 3)) (+ a b c))))
(LET ((A
1)
(B
2)
(C
3))
(+ A B
C))
; No value
CL-USER> (let ((*print-right-margin* 20))
(pprint '(let ((a 1) (b 2) (c 3)) (+ a b c))))
(LET ((A 1)
(B 2)
(C 3))
(+ A B C))
; No value您可能通过设置该变量就可以获得满意的结果,但是通常您希望了解一下22.2 Lisp漂亮打印机。漂亮的打印函数有很多可选换行符之类的地方,它们的放置位置取决于许多事情(比如*打印-右边*和*打印-守财奴-宽度*)。有一些使用漂亮打印机在22.2.2使用漂亮打印机的示例中格式化Lisp源代码的示例。引用的内容太多了,但它显示了以下漂亮的打印代码如何根据上下文生成所有这些输出:
(defun simple-pprint-defun (*standard-output* list)
(pprint-logical-block (*standard-output* list :prefix "(" :suffix ")")
(write (first list))
(write-char #\Space)
(pprint-newline :miser)
(pprint-indent :current 0)
(write (second list))
(write-char #\Space)
(pprint-newline :fill)
(write (third list))
(pprint-indent :block 1)
(write-char #\Space)
(pprint-newline :linear)
(write (fourth list)))) (DEFUN PROD (X Y)
(* X Y))(DEFUN PROD
(X Y)
(* X Y)) (DEFUN
PROD
(X Y)
(* X Y)) ;;; (DEFUN PROD
;;; (X Y)
;;; (* X Y))https://stackoverflow.com/questions/24295314
复制相似问题