假设我有以下代码,其中显示了mapcar的用法示例
(mapcar #'1+ (list 10 20 30)) ; ⇒ (11 21 31)
(mapcar (lambda (it)
(* 2 it))
(list 0 1 2 3))
;; ⇒ (0 2 4 6)
(require cl-lib)
(cl-mapcar #'+
'(1 2 3)
'(10 20 30))
;; ⇒ (11 22 33)我可能会把代码写在某个地方,这样我就可以在教程中使用它,或者每当我忘记mapcar是如何工作的时候,我就可以快速阅读代码。
现在假设我想要更新代码中的一些示例。例如,我可以将第二个示例中的(list 0 1 2 3)更改为其他列表。在我更改示例之后,相应的结果注释就过时了。结果注释也需要更新。因此,我评估表单,复制结果,并将注释中的旧结果替换为新结果。有没有什么包可以帮我轻松轻松地做到这一点?这是一个与litable或ielm包解决的问题不同的问题,因为这只是更新现有的示例代码。
现在我使用的是:
(defun my-insert-eval-last-sexp ()
(interactive)
(let ((beg (point)))
(let ((current-prefix-arg '(4)))
(call-interactively 'eval-last-sexp))
(goto-char beg)
(if (looking-back ")")
(insert " ; "))
(insert "⇒ ")
(move-end-of-line 1)))这仍然是不够的,因为它只是添加结果注释,而不是更新旧的注释,并且在表单计算为数字时会插入奇怪的东西:
(+ 1 2)
;; ⇒ 3 (#o3, #x3)发布于 2013-08-17 10:59:29
嗯,我不确定我是否想鼓励这种事情;-),但这会让你离你试图做的事情更近一步,IIUC:
(defun my-insert-eval-last-sexp ()
(interactive)
(let ((this-command 'eval-print-last-sexp))
(save-excursion (eval-last-sexp-1 t)))
(when (looking-back ")") (insert " ; "))
(insert "⇒ ")
(move-end-of-line 1))使用save-excursion.
:let绑定可以做到这一点(但这是一个丑陋的小技巧)。
发布于 2013-08-17 15:27:53
你的函数所做的每件事都是在org-mode中实现的,即org-babel。
请参阅在信息中,组织模式,14使用源代码
https://stackoverflow.com/questions/18284497
复制相似问题