[ESS] `font-lock-pre-idle-hook': Error message any time I type in xemacs
Brian Diggs
diggsb at ohsu.edu
Mon Mar 22 21:46:15 CET 2010
On 3/19/2010 6:58 AM, Rodney Sparapani wrote:
> On 03/18/10 05:37 PM, Brian Diggs wrote:
>>
>> It is not just an Ubuntu issue. I also see it with ESS 5.8 under XEmacs
>> 21.4.21 on Windows XP. I can get the errors to go away and the font
>> locking to work correctly if I turn off font-lock-mode and then turn it
>> back on. However, this has to be done individually for every ESS[S]
>> buffer separately.
>>
>> Since turning off and turning on font-lock-mode fixes it, I am guessing
>> it has something to do with how font-lock-mode is enabled for buffers.
>> However, I don't know where to look to start figuring it out. I would be
>> happy to do some hunting if someone could give me directions as to what
>> to look for.
>>
>> --
>> Brian Diggs
>
> I cannot replicate your issue with ESS 5.8 under XEmacs 21.4.21
> on Windows XP. Do you have to do anything in particular or is
> it just automatic?
>
> Rodney
It is automatic. I've tried to determine if it is something in my
configuration, but can not find anything. Here are the steps that I can
take to reproduce it.
Start XEmacs (-q and -no-site-file are not necessary for the problem,
but I wanted to isolate that it is not something in my configuration)
"C:\Program Files\XEmacs\XEmacs-21.4.21\i586-pc-win32\xemacs.exe" -q
-no-site-file
In *scratch* buffer:
(require 'ess-site)
Using C-j to execute it. I should note that no *ESS* buffer appears; it
just stays in *scratch*, though there is an *ESS* buffer in the buffer list.
Open a .R file:
C-x C-f ~/test.R
Type anything; after first keypress get the warning (in the *Warnings*
buffer):
(1) (warning/warning) Error caught in `font-lock-pre-idle-hook':
(invalid-function 0)
If it is useful, the contents of the *ESS* buffer are:
[ess-site.el]: ess-customize-alist=nil
[ess-site.el _2_]: ess-customize-alist=nil
(ess-find-rterm): ess-R-root-dir = 'c:\Program Files\'
(R): ess-r-versions-create making M-x defuns for
(ess-setq-vars-LOCAL): language=S, dialect=R, buf=nil,
comint..echoes=nil, comint..sender=comint-simple-send
(ess-mode-1): ess-language=S, ess-dialect=R buf=test.R
(ess-mode-1.5): alist=((ess-local-customize-alist quote
R-customize-alist) (ess-dialect . R) (ess-suffix . R)
(ess-dump-filename-template ess-replace-regexp-in-string S$ ess-suffix
ess-dump-filename-template-proto) (ess-mode-syntax-table .
R-syntax-table) (ess-mode-editing-alist . R-editing-alist)
(ess-change-sp-regexp . ess-R-change-sp-regexp) (ess-help-sec-regex .
ess-help-R-sec-regex) (ess-help-sec-keys-alist .
ess-help-R-sec-keys-alist) (ess-loop-timeout . ess-S-loop-timeout)
(ess-cmd-delay . ess-R-cmd-delay) (ess-function-pattern .
ess-R-function-pattern) (ess-object-name-db-file . ess-r-namedb.el)
(ess-imenu-mode-function quote ess-imenu-R) (inferior-ess-program .
inferior-R-program-name) (inferior-ess-objects-command .
inferior-R-objects-command) (inferior-ess-font-lock-keywords .
inferior-ess-R-font-lock-keywords) (inferior-ess-search-list-command .
search()
) (inferior-ess-help-command . inferior-ess-r-help-command)
(inferior-ess-help-filetype) (inferior-ess-exit-command . q())
(inferior-ess-exit-prompt . Save workspace image? [y/n/c]: )
(inferior-ess-primary-prompt . \([A-Z][][A-Za-z0-9.]*\)?> )
(inferior-ess-secondary-prompt . + ?) (inferior-ess-start-file)
(inferior-ess-start-args . ) (ess-STERM . iESS) (ess-editor . R-editor)
(ess-pager . R-pager) (ess-language . S) (inferior-ess-exit-command . q()
) (inferior-ess-language-start eval inferior-S-language-start)
(comint-use-prompt-regexp-instead-of-fields . t))
(ess-mode-1.6): editing-alist=((paragraph-start concat \s-*$\|
page-delimiter) (paragraph-separate concat \s-*$\| page-delimiter)
(paragraph-ignore-fill-prefix . t) (require-final-newline . t)
(comment-start . #) (comment-add . 1) (comment-start-skip . #+ *)
(comment-column . 40) (indent-line-function quote S-indent-line)
(parse-sexp-ignore-comments . t) (ess-style . ess-default-style)
(ess-local-process-name) (ess-mode-syntax-table . S-syntax-table)
(add-log-current-defun-header-regexp . ^\(.+\)\s-+<-[
]*function) (font-lock-defaults quote (ess-R-mode-font-lock-keywords nil
nil ((?\. . w) (?_ . w)))))
(ess-setq-vars-LOCAL): language=S, dialect=R, buf=nil,
comint..echoes=nil, comint..sender=comint-simple-send
Finished setting up ESS-mode.
And the contents of the *Message-Log* buffer are:
Loading cus-face...
Loading cus-face...done
Loading regexp-opt...
Loading regexp-opt...done
enabling speedbar support
Loading efs-cu...
Loading efs-cu...done
(New file)
Loading ess-roxy...
Loading edmacro...
Loading edmacro...done
Loading easy-mmode...
Loading easy-mmode...done
Loading advice...
Loading advice...done
Loading ess-roxy...done
I have found an even simpler way to work around the problem. In the
misbehaving buffer, if I manually run 'R-mode' again, the font locking
works as expected. This is a shorter invocation than my previous
workaround ('font-lock-mode', 'font-lock-mode'). However, it is still a
per-buffer workaround.
--
--
Brian Diggs
Senior Research Associate, Department of Surgery, Oregon Health &
Science University
More information about the ESS-help
mailing list