emacs-orgmode
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [O] [Babel] [PATCH] Customize regular expression to match noweb refe


From: Eric Schulte
Subject: Re: [O] [Babel] [PATCH] Customize regular expression to match noweb references
Date: Fri, 27 Jan 2012 16:05:54 -0700
User-agent: Gnus/5.13 (Gnus v5.13) Emacs/24.0.92 (gnu/linux)

Good idea,

I've changed your implementation to rely on two new customization
variables `org-babel-noweb-wrap-start' and `org-babel-noweb-wrap-end' as
this provides more flexibility to the backend implementation to place
constraints on the properties of the noweb names.

In you're situation you will now want to set...
(setq org-babel-noweb-wrap-start "«"
      org-babel-noweb-wrap-end   "»")

Thanks for the great idea,

"Sean O'Halpin" <address@hidden> writes:

> Hi,
>
> Here's a patch I'm using to change the default regular expression used
> to match noweb references.
> The default regular expression "<<\\(.+?\\)>>" conflicts with Ruby
> syntax and confuses syntax highlighting.
> I now set this to "«\\(.+?\\)»", i.e. using guillemots instead
> (AltGr-z and AltGr-x on my keyboard).
>
> Regards,
> Sean
>
>
> Customizable regular expression to match noweb references.
> ---
>  lisp/ob-tangle.el |    4 +++-
>  lisp/ob.el        |    7 ++++++-
>  2 files changed, 9 insertions(+), 2 deletions(-)
>
> diff --git a/lisp/ob-tangle.el b/lisp/ob-tangle.el
> index d7c4d7e..4148774 100644
> --- a/lisp/ob-tangle.el
> +++ b/lisp/ob-tangle.el
> @@ -281,12 +281,14 @@ references."
>    (interactive)
>    (goto-char (point-min))
>    (while (or (re-search-forward "\\[\\[file:.*\\]\\[.*\\]\\]" nil t)
> -             (re-search-forward "<<[^[:space:]]*>>" nil t))
> +             (re-search-forward org-babel-noweb-regexp nil t))
>      (delete-region (save-excursion (beginning-of-line 1) (point))
>                     (save-excursion (end-of-line 1) (forward-char 1) 
> (point)))))
>
>  (defvar org-stored-links)
>  (defvar org-bracket-link-regexp)
> +(defvar org-babel-noweb-regexp)
> +
>  (defun org-babel-tangle-collect-blocks (&optional language)
>    "Collect source blocks in the current Org-mode file.
>  Return an association list of source-code block specifications of
> diff --git a/lisp/ob.el b/lisp/ob.el
> index 47be708..bbd6209 100644
> --- a/lisp/ob.el
> +++ b/lisp/ob.el
> @@ -113,6 +113,11 @@ remove code block execution from the C-c C-c keybinding."
>    :group 'org-babel
>    :type 'boolean)
>
> +(defcustom org-babel-noweb-regexp "<<\\(.+?\\)>>"
> +  "Regular expression to use to match noweb references."
> +  :group 'org-babel
> +  :type 'string)
> +
>  (defcustom org-babel-results-keyword "RESULTS"
>    "Keyword used to name results generated by code blocks.
>  Should be either RESULTS or NAME however any capitalization may
> @@ -2159,7 +2164,7 @@ block but are passed literally to the 
> \"example-block\"."
>        (with-temp-buffer
>          (insert body) (goto-char (point-min))
>          (setq index (point))
> -        (while (and (re-search-forward "<<\\(.+?\\)>>" nil t))
> +        (while (and (re-search-forward org-babel-noweb-regexp nil t))
>            (save-match-data (setf source-name (match-string 1)))
>            (save-match-data (setq evaluate (string-match "\(.*\)" 
> source-name)))
>            (save-match-data

-- 
Eric Schulte
http://cs.unm.edu/~eschulte/



reply via email to

[Prev in Thread] Current Thread [Next in Thread]