unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* eval-to-texi
@ 2004-04-30 14:45 jemarch
  2004-05-03 16:39 ` eval-to-texi Stefan Monnier
  2004-05-03 20:48 ` eval-to-texi Kevin Rodgers
  0 siblings, 2 replies; 11+ messages in thread
From: jemarch @ 2004-04-30 14:45 UTC (permalink / raw)




2004-04-30  Jose E. Marchesi  <jemarch@gnu.org>

	* textmodes/texinfo.el (texinfo-eval-to-texi): New function.





*** texinfo.el.~1.102.~	Sat Feb 21 14:48:44 2004
--- texinfo.el	Fri Apr 30 16:42:38 2004
***************
*** 1050,1055 ****
--- 1050,1155 ----
    ;;               job-number"\n"))
    (tex-recenter-output-buffer nil))
  
+ 
+ (defun texinfo-eval-to-texi (form &optional tostring)
+   "Evaluates FORM, dumping a @lisp texinfo environment with the evaluation
+ description.
+ 
+ If TOSTRING is t, then the @lisp environment is returned into a string,
+ rather than being inserted into the current buffer."
+   
+   (interactive "sForm to evaluate: ")
+ 
+   (let (environment-text)
+ 
+     (setq environment-text 
+ 
+ 	  (with-temp-buffer 
+ 
+ 	    (condition-case error-description
+ 
+ 		(let (expression result output)
+ 
+ 		  ;; Begin of the sample
+ 		  (insert "@lisp\n")
+ 
+ 		  ;; Dump the form itself into the sample
+ 		  (let ((tform form))
+ 
+ 		     (setq tform (replace-regexp-in-string "@" "@@" tform))
+ 		     (setq tform (replace-regexp-in-string "{" "@{" tform))
+ 		     (setq tform (replace-regexp-in-string "}" "@}" tform))
+ 
+ 		     (insert tform "\n"))
+ 
+ 		  ;; Parse the form to a valid expression
+ 		  (setq expression (read form))
+ 
+ 
+ 
+ 		  ;; Get the result of the eval, and the output if there is one
+ 		  (setq output 
+ 			(with-output-to-string
+ 			  (setq result (prin1-to-string (eval expression)))))
+ 
+ 		  ;; If there is any output, dump a @print{} entry into the sample
+ 		  (if (not (equal output ""))
+ 
+ 		      (progn
+ 			;; Escape texinfo special characters on the output
+ 			(setq output (replace-regexp-in-string "@" "@@" output))
+ 			(setq output (replace-regexp-in-string "{" "@{" output))
+ 			(setq output (replace-regexp-in-string "}" "@}" output))
+ 
+ 			;; Indent multilines
+ 			(setq output (replace-regexp-in-string "\n" "\n          " output))
+ 
+ 			(insert "      @print{} " output "\n")))
+ 
+ 		  ;; If the expression is a macro, dump an @expansion{}
+ 		  (let ((macroexp (macroexpand expression)))
+ 		    (if (not (equal macroexp expression))  ; macro-p???
+ 
+ 			(let ((met (prin1-to-string macroexp)))
+ 
+ 			  ;; Escape texinfo special characters on the macro expansion text
+ 			  (setq met (replace-regexp-in-string "@" "@@" met))
+ 			  (setq met (replace-regexp-in-string "{" "@{" met))
+ 			  (setq met (replace-regexp-in-string "}" "@}" met))
+ 
+ 			  ;; Indent multilines
+ 			  (setq met (replace-regexp-in-string "\n" "\n          " met))
+ 
+ 			  (insert "      @expansion{} " met "\n"))))
+ 
+ 		  ;; Escape texinfo special characters on the result
+ 		  (setq result (replace-regexp-in-string "@" "@@" result))
+ 		  (setq result (replace-regexp-in-string "{" "@{" result))
+ 		  (setq result (replace-regexp-in-string "}" "@}" result))
+ 
+ 		  ;; Indent multilines
+ 		  (setq result (replace-regexp-in-string "\n" "\n          " result))
+ 
+ 		  ;; Dump the @result{} entry into the sample
+ 		  (insert "      @result{} " result "\n"))
+ 
+ 	      ;; Was an error => Dump an @error{} entry into the sample with the error
+ 	      ;; description from the interpreter
+ 	      (error (insert "      @error{} " (error-message-string error-description) "\n")))
+ 
+ 	    ;; End of the sample
+ 	    (insert "@end lisp")
+ 
+ 	    ;; Return buffer's contents
+ 	    (buffer-substring (point-min) (point-max))))
+ 
+ 
+     (if (not tostring)
+ 	(insert environment-text)
+       environment-text)))    
+ 
+ 
+ 
  (provide 'texinfo)
  
  ;;; arch-tag: 005d7c38-43b9-4b7d-aa1d-aea69bae73e1

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-05-03 16:39 ` eval-to-texi Stefan Monnier
@ 2004-04-30 17:45   ` jemarch
  2004-05-03 18:21     ` eval-to-texi Adrian Aichner
  0 siblings, 1 reply; 11+ messages in thread
From: jemarch @ 2004-04-30 17:45 UTC (permalink / raw)
  Cc: emacs-devel




   > + 		     (setq tform (replace-regexp-in-string "@" "@@" tform))
   > + 		     (setq tform (replace-regexp-in-string "{" "@{" tform))
   > + 		     (setq tform (replace-regexp-in-string "}" "@}" tform))

   Aka (setq tform (replace-regexp-in-string "[@{}]" "@\\&" tform))


Ok, thanks. Changed in the following patch.




*** texinfo.el.~1.102.~	Sat Feb 21 14:48:44 2004
--- texinfo.el	Fri Apr 30 19:43:07 2004
***************
*** 1050,1055 ****
--- 1050,1147 ----
    ;;               job-number"\n"))
    (tex-recenter-output-buffer nil))
  
+ 
+ (defun texinfo-eval-to-texi (form &optional tostring)
+   "Evaluates FORM, dumping a @lisp texinfo environment with the evaluation
+ description.
+ 
+ If TOSTRING is t, then the @lisp environment is returned into a string,
+ rather than being inserted into the current buffer."
+   
+   (interactive "sForm to evaluate: ")
+ 
+   (let (environment-text)
+ 
+     (setq environment-text 
+ 
+ 	  (with-temp-buffer 
+ 
+ 	    (condition-case error-description
+ 
+ 		(let (expression result output)
+ 
+ 		  ;; Begin of the sample
+ 		  (insert "@lisp\n")
+ 
+ 		  ;; Dump the form itself into the sample
+ 		  (let ((tform form))
+ 
+ 		    (setq tform (replace-regexp-in-string "[@{}]" "@\\&" tform))
+ 
+ 		     (insert tform "\n"))
+ 
+ 		  ;; Parse the form to a valid expression
+ 		  (setq expression (read form))
+ 
+ 
+ 
+ 		  ;; Get the result of the eval, and the output if there is one
+ 		  (setq output 
+ 			(with-output-to-string
+ 			  (setq result (prin1-to-string (eval expression)))))
+ 
+ 		  ;; If there is any output, dump a @print{} entry into the sample
+ 		  (if (not (equal output ""))
+ 
+ 		      (progn
+ 			;; Escape texinfo special characters on the output
+ 			(setq output (replace-regexp-in-string "[@{}]" "@\\&" output))
+ 
+ 			;; Indent multilines
+ 			(setq output (replace-regexp-in-string "\n" "\n          " output))
+ 
+ 			(insert "      @print{} " output "\n")))
+ 
+ 		  ;; If the expression is a macro, dump an @expansion{}
+ 		  (let ((macroexp (macroexpand expression)))
+ 		    (if (not (equal macroexp expression))  ; macro-p???
+ 
+ 			(let ((met (prin1-to-string macroexp)))
+ 
+ 			  ;; Escape texinfo special characters on the macro expansion text
+ 			  (setq met (replace-regexp-in-string "[@{}]" "@\\&" met))
+ 
+ 			  ;; Indent multilines
+ 			  (setq met (replace-regexp-in-string "\n" "\n          " met))
+ 
+ 			  (insert "      @expansion{} " met "\n"))))
+ 
+ 		  ;; Escape texinfo special characters on the result
+ 		  (setq result (replace-regexp-in-string "[@{}]" "@\\&" result))
+ 
+ 		  ;; Indent multilines
+ 		  (setq result (replace-regexp-in-string "\n" "\n          " result))
+ 
+ 		  ;; Dump the @result{} entry into the sample
+ 		  (insert "      @result{} " result "\n"))
+ 
+ 	      ;; Was an error => Dump an @error{} entry into the sample with the error
+ 	      ;; description from the interpreter
+ 	      (error (insert "      @error{} " (error-message-string error-description) "\n")))
+ 
+ 	    ;; End of the sample
+ 	    (insert "@end lisp")
+ 
+ 	    ;; Return buffer's contents
+ 	    (buffer-substring (point-min) (point-max))))
+ 
+ 
+     (if (not tostring)
+ 	(insert environment-text)
+       environment-text)))    
+ 

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-05-03 18:21     ` eval-to-texi Adrian Aichner
@ 2004-04-30 18:38       ` jemarch
  2004-05-04  7:40         ` eval-to-texi David Kastrup
  0 siblings, 1 reply; 11+ messages in thread
From: jemarch @ 2004-04-30 18:38 UTC (permalink / raw)
  Cc: emacs-devel

    Adrian Aichner writes:
    jemarch@gnu.org writes:
    
    > + (defun texinfo-eval-to-texi (form &optional tostring)
    > +   "Evaluates FORM, dumping a @lisp texinfo environment with the evaluation
    > + description.
    > + 
    > + If TOSTRING is t, then the @lisp environment is returned into a string,
    > + rather than being inserted into the current buffer."
    > +   
    > +   (interactive "sForm to evaluate: ")
    > + 
    > +   (let (environment-text)
    > + 
    > +     (setq environment-text 
    > + 
    > + 	  (with-temp-buffer 
    > + 
    > + 	    (condition-case error-description
    > + 
    > + 		(let (expression result output)
    > + 
    
    Hi, just my two cents: why the excessive whitespace?

¿Do you mean the line spacing? In this way i found easier to read the
code. It is a personal taste, of course. The spacing can be reduced.


-- 
José E. Marchesi 

<jemarch@gnu.org>         http://www.gnu.org     GNU No es Unix!
<jemarch@es.gnu.org>      http://es.gnu.org      GNU España

.---------------.
|    .-[]--.    |
|   [] `>[]-|   |  BEE GNU/Hurd            http://bee.es.gnu.org
|    `-.[]<-'   |               
._______________.    

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-04-30 14:45 eval-to-texi jemarch
@ 2004-05-03 16:39 ` Stefan Monnier
  2004-04-30 17:45   ` eval-to-texi jemarch
  2004-05-03 20:48 ` eval-to-texi Kevin Rodgers
  1 sibling, 1 reply; 11+ messages in thread
From: Stefan Monnier @ 2004-05-03 16:39 UTC (permalink / raw)
  Cc: emacs-devel

> + 		     (setq tform (replace-regexp-in-string "@" "@@" tform))
> + 		     (setq tform (replace-regexp-in-string "{" "@{" tform))
> + 		     (setq tform (replace-regexp-in-string "}" "@}" tform))

Aka (setq tform (replace-regexp-in-string "[@{}]" "@\\&" tform))


        Stefan

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-04-30 17:45   ` eval-to-texi jemarch
@ 2004-05-03 18:21     ` Adrian Aichner
  2004-04-30 18:38       ` eval-to-texi jemarch
  0 siblings, 1 reply; 11+ messages in thread
From: Adrian Aichner @ 2004-05-03 18:21 UTC (permalink / raw)



jemarch@gnu.org writes:

> *** texinfo.el.~1.102.~	Sat Feb 21 14:48:44 2004
> --- texinfo.el	Fri Apr 30 19:43:07 2004
> ***************
> *** 1050,1055 ****
> --- 1050,1147 ----
>     ;;               job-number"\n"))
>     (tex-recenter-output-buffer nil))
>   
> + 
> + (defun texinfo-eval-to-texi (form &optional tostring)
> +   "Evaluates FORM, dumping a @lisp texinfo environment with the evaluation
> + description.
> + 
> + If TOSTRING is t, then the @lisp environment is returned into a string,
> + rather than being inserted into the current buffer."
> +   
> +   (interactive "sForm to evaluate: ")
> + 
> +   (let (environment-text)
> + 
> +     (setq environment-text 
> + 
> + 	  (with-temp-buffer 
> + 
> + 	    (condition-case error-description
> + 
> + 		(let (expression result output)
> + 

Hi, just my two cents: why the excessive whitespace?

-- 
Adrian Aichner
 mailto:adrian@xemacs.org
 http://www.xemacs.org/

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-04-30 14:45 eval-to-texi jemarch
  2004-05-03 16:39 ` eval-to-texi Stefan Monnier
@ 2004-05-03 20:48 ` Kevin Rodgers
  2004-05-03 21:24   ` eval-to-texi Stefan Monnier
  2004-05-05  1:17   ` eval-to-texi Jose E. Marchesi
  1 sibling, 2 replies; 11+ messages in thread
From: Kevin Rodgers @ 2004-05-03 20:48 UTC (permalink / raw)


jemarch@gnu.org wrote:
 > + (defun texinfo-eval-to-texi (form &optional tostring)
 > +   "Evaluates FORM, dumping a @lisp texinfo environment with the evaluation
 > + description.
 > +
 > + If TOSTRING is t, then the @lisp environment is returned into a string,
 > + rather than being inserted into the current buffer."
 > +
 > +   (interactive "sForm to evaluate: ")

How about making its interface more like shell-command:

(defun texinfo-eval-to-texi (form &optional insert)
   "Evaluate FORM, and display it and the result as a @lisp Texinfo command.
With a prefix argument, insert the Texinfo command in the current buffer.

When called from Lisp, the command is returned as a string."
   (interactive "sForm to evaluate: \nP")
...
   (if insert
       (insert texinfo-command)
     (with-output-to-temp-buffer "*Texinfo*"
       ;; too bad we can't force the buffer into texinfo-mode
       (princ texinfo-command)))
   texinfo-command)

-- 
Kevin Rodgers

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-05-03 20:48 ` eval-to-texi Kevin Rodgers
@ 2004-05-03 21:24   ` Stefan Monnier
  2004-05-05  1:17   ` eval-to-texi Jose E. Marchesi
  1 sibling, 0 replies; 11+ messages in thread
From: Stefan Monnier @ 2004-05-03 21:24 UTC (permalink / raw)
  Cc: emacs-devel

> How about making its interface more like shell-command:

You mean make it more like `eval-expression'?  Agreed.
Actually, now that you mention it, it would be even neater to
extend `eval-expression' such that major modes can tune the format in which
the output is written in the current buffer.  Then texinfo-mode can make it
do what texinfo-eval-to-texi does.


        Stefan

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-04-30 18:38       ` eval-to-texi jemarch
@ 2004-05-04  7:40         ` David Kastrup
  2004-05-04  8:51           ` eval-to-texi Juri Linkov
  0 siblings, 1 reply; 11+ messages in thread
From: David Kastrup @ 2004-05-04  7:40 UTC (permalink / raw)
  Cc: emacs-devel, Adrian Aichner

jemarch@gnu.org writes:

>     Hi, just my two cents: why the excessive whitespace?
> 
> ¿Do you mean the line spacing? In this way i found easier to read
> the code. It is a personal taste, of course. The spacing can be
> reduced.

Please do so.  Emacs code is usually formatted in a particular
style.  This style is also described in the Elisp manual AFAIR.

-- 
David Kastrup, Kriemhildstr. 15, 44793 Bochum

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-05-04  7:40         ` eval-to-texi David Kastrup
@ 2004-05-04  8:51           ` Juri Linkov
  2004-05-04 15:31             ` eval-to-texi Miles Bader
  0 siblings, 1 reply; 11+ messages in thread
From: Juri Linkov @ 2004-05-04  8:51 UTC (permalink / raw)
  Cc: emacs-devel, adrian, jemarch

David Kastrup <dak@gnu.org> writes:
> jemarch@gnu.org writes:
>>     Hi, just my two cents: why the excessive whitespace?
>> 
>> ¿Do you mean the line spacing? In this way i found easier to read
>> the code. It is a personal taste, of course. The spacing can be
>> reduced.
>
> Please do so.  Emacs code is usually formatted in a particular
> style.  This style is also described in the Elisp manual AFAIR.

Does anyone know about such already implemented function that formats
Emacs code according to a style described in the Elisp manual?

I'm thinking about calling it by typing `C-u C-M-q' which might do
a better job than `pp' does.

-- 
Juri Linkov
http://www.jurta.org/emacs/

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-05-04  8:51           ` eval-to-texi Juri Linkov
@ 2004-05-04 15:31             ` Miles Bader
  0 siblings, 0 replies; 11+ messages in thread
From: Miles Bader @ 2004-05-04 15:31 UTC (permalink / raw)


Juri Linkov <juri@jurta.org> writes:
> I'm thinking about calling it by typing `C-u C-M-q' which might do
> a better job than `pp' does.

It could hardly do it worse...

[I have pleasant memories of lisps where pp would actually turn out
half-way decent looking code...]

-Miles
-- 
If you can't beat them, arrange to have them beaten.  [George Carlin]

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: eval-to-texi
  2004-05-03 20:48 ` eval-to-texi Kevin Rodgers
  2004-05-03 21:24   ` eval-to-texi Stefan Monnier
@ 2004-05-05  1:17   ` Jose E. Marchesi
  1 sibling, 0 replies; 11+ messages in thread
From: Jose E. Marchesi @ 2004-05-05  1:17 UTC (permalink / raw)
  Cc: emacs-devel



    jemarch@gnu.org wrote:
     > + (defun texinfo-eval-to-texi (form &optional tostring)
     > +   "Evaluates FORM, dumping a @lisp texinfo environment with the evaluation
     > + description.
     > +
     > + If TOSTRING is t, then the @lisp environment is returned into a string,
     > + rather than being inserted into the current buffer."
     > +
     > +   (interactive "sForm to evaluate: ")

    How about making its interface more like shell-command:


I think it is a good idea. With your permission, i am going to get
also your doc string.



--
José E. Marchesi

<jemarch@gnu.org>         http://www.gnu.org     GNU No es Unix!
<jemarch@es.gnu.org>      http://es.gnu.org      GNU Españaa

.---------------.
|    .-[]--.    |
|   [] `>[]-|   |  BEE GNU/Hurd            http://bee.es.gnu.org
|    `-.[]<-'   |             
.---------------.             

^ permalink raw reply	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2004-05-05  1:17 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2004-04-30 14:45 eval-to-texi jemarch
2004-05-03 16:39 ` eval-to-texi Stefan Monnier
2004-04-30 17:45   ` eval-to-texi jemarch
2004-05-03 18:21     ` eval-to-texi Adrian Aichner
2004-04-30 18:38       ` eval-to-texi jemarch
2004-05-04  7:40         ` eval-to-texi David Kastrup
2004-05-04  8:51           ` eval-to-texi Juri Linkov
2004-05-04 15:31             ` eval-to-texi Miles Bader
2004-05-03 20:48 ` eval-to-texi Kevin Rodgers
2004-05-03 21:24   ` eval-to-texi Stefan Monnier
2004-05-05  1:17   ` eval-to-texi Jose E. Marchesi

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).