unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
From: martin rudalics <rudalics@gmx.at>
Cc: emacs-devel@gnu.org
Subject: Re: diary font-lock issue
Date: Tue, 16 May 2006 17:50:06 +0200	[thread overview]
Message-ID: <4469F4AE.8030909@gmx.at> (raw)
In-Reply-To: <8jwtcmqvqm.fsf@fencepost.gnu.org>

[-- Attachment #1: Type: text/plain, Size: 2059 bytes --]

 > elisp:
 > -------
 > (setq foo-font-lock-keywords
 >       '(("\\(\\(?:Fri\\|Mon\\|S\\(?:atur\\|un\\)\\|\\(?:T\\(?:hur\\|ue\\)\\|Wedne\\)s\\)day\\), \\(A\\(?:pril\\|ugust\\)\\|December\\|February\\|J\\(?:anuary\\|u\\(?:ly\\|ne\\)\\)\\|Ma\\(?:rch\\|y\\)\\|\\(?:Novem\\|Octo\\|Septem\\)ber\\) 
[0-9]+, -?[0-9]+\n=+$" . font-lock-keyword-face)))
 >
 > (define-derived-mode foo-mode fundamental-mode
 >   "foo"
 >   (set (make-local-variable 'font-lock-defaults)
 >        '(foo-font-lock-keywords t))
 >   (set (make-local-variable 'font-lock-multiline) t))
 >
 >
 > sample input file:
 > -------
 > Friday, May 5, 2006
 > ===================
 > 9.00 Xxxx Xxxxxx Xxxxx xXxxxxxxxxxxxx
 > 15.20-15.50 Xxxx Xxxxxxxxxxxxxxxxx
 > 17.30-19.00 Xxxx Xxxxxxxxxx
 > 18.00-19.30 Xxxx XXX
 >
 > Monday, May 8, 2006
 > ===================
 > 8.00 Xxxxxxxx xx Xxxxxxxx Xxxxxxxxxx xxx Xxxxxxxxxxxxx
 > 14.30 Xxxxxx XxxxxXXxXxxxxx xxx Xxxx
 > 15.30-17.00 Xxxx XxxxxXX
 > 16.45 Xxxx xxx XxxxxXX xxxxxxx
 > 17.15-18.15 Xxxx XxxxxXx
 >
 > Tuesday, May 9, 2006
 > ====================
 > 14.50 Xxxx xxx Xxxxxxxxxxxxxxxxxxxxx xxxxxxx
 > 15.30-16.00 Xxxx
 >
 > Wednesday, May 10, 2006

<----------------------------------- end of font-lock-fontify-region

 > =======================
 > 20.00-21.15 Xxxxxx Xxxxxx

`foo-font-lock-keywords' will fail to find a match when the end of
`font-lock-fontify-region' is positioned as indicated above.

Earlier it was possible to handle this - in most cases - by setting
`font-lock-lines-before' to 1, but I don't know how this will be done in
the future.  So far you could try the largely untested code I attached.

As soon as `font-lock-extend-region' has undergone its final revision
you should be able to replace the after-change-hook by writing an
appropriate `font-lock-extend-region-function'.  If
`font-lock-extend-region' will be regularly called by say
`font-lock-default-fontify-region', you will have to simply check
whether the first character to be fontified is an "=" and you may use
your original code practically unchanged.


[-- Attachment #2: foo-mode --]
[-- Type: text/plain, Size: 1516 bytes --]

(defun foo-bar (bound)
  (let (beg end)
    (and (re-search-forward
	  "\\(\\(?:\\(?:Fri\\|Mon\\|S\\(?:atur\\|un\\)\\|\\(?:T\\(?:hur\\|ue\\)\\|Wedne\\)s\\)day\\)\
, \\(?:A\\(?:pril\\|ugust\\)\\|December\\|February\\|J\\(?:anuary\\|u\\(?:ly\\|ne\\)\\)\
\\|Ma\\(?:rch\\|y\\)\\|\\(?:Novem\\|Octo\\|Septem\\)ber\\) [0-9]+, -?[0-9]+\n\\)\\(=+\n\\)?" bound t)
	 (or (and (> (match-end 0) (match-end 1))
		  (setq beg (match-beginning 0))
		  (setq end (match-end 0)))
	     (and (= (match-end 1) bound)
		  (setq beg (match-beginning 0))
		  (save-excursion
		    (save-match-data
		      (and (looking-at "=+\n")
			   (setq end (match-end 0)))))))
	 (and beg end
	      (or (put-text-property beg end 'font-lock-multiline t) t)))))

(setq foo-font-lock-keywords
      '((foo-bar 1 'font-lock-keyword-face)))

(defun foo-mode-after-change (start end old-len)
  (save-excursion
    (goto-char start)
    (beginning-of-line)
    (when (eq (char-after) ?\=))
      (let* ((buffer-undo-list t)
	     (inhibit-read-only t)
	     (inhibit-point-motion-hooks t)
	     (inhibit-modification-hooks t)
	     deactivate-mark
	     buffer-file-name
	     buffer-file-truename)
	(put-text-property
	 (line-beginning-position 0) (line-beginning-position) 'fontified nil))))

(define-derived-mode foo-mode fundamental-mode
  "foo"
  (set (make-local-variable 'font-lock-defaults)
       '(foo-font-lock-keywords t))
  (set (make-local-variable 'font-lock-multiline) t)
  (add-hook 'after-change-functions 'foo-mode-after-change nil t))

[-- Attachment #3: Type: text/plain, Size: 142 bytes --]

_______________________________________________
Emacs-devel mailing list
Emacs-devel@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-devel

  reply	other threads:[~2006-05-16 15:50 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-05-16  7:22 diary font-lock issue Glenn Morris
2006-05-16 15:50 ` martin rudalics [this message]
2006-05-16 17:56   ` Glenn Morris
2006-05-16 21:42     ` martin rudalics
2006-05-17 15:11     ` Stefan Monnier
2006-05-17 15:05 ` Stefan Monnier
2006-05-17 19:11   ` Glenn Morris
2006-05-17 21:15     ` Stefan Monnier
2006-05-21 10:39   ` martin rudalics

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4469F4AE.8030909@gmx.at \
    --to=rudalics@gmx.at \
    --cc=emacs-devel@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).