unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags
@ 2013-03-20  3:36 Dmitry Gutov
  2013-03-26 16:49 ` Stefan Monnier
  2013-04-01 13:32 ` Stefan Monnier
  0 siblings, 2 replies; 5+ messages in thread
From: Dmitry Gutov @ 2013-03-20  3:36 UTC (permalink / raw)
  To: 14003

sgml-mode has some support for preprocessing tags.
When it sees tags with percent characters inside (<% hello! %>), it says
that the tag's type is `jsp'.

The templating engine may be different (e.g. ERB or EJS), but all of
these examples can have arbitrary code inside, including angle brackets,
usually serving as comparison operators.

Before revno:111900, only having "<" inside a `jsp' tag was a problem:
it broke indentation on the following lines, until a closing containing
tag. With the aforementioned revision, having either "<" or ">" inside a
`jsp' tag breaks string highlighting, because they changes the depth in
parens returned by (syntax-ppss).

So, the previously discussed general problem
(http://lists.gnu.org/archive/html/emacs-devel/2012-06/msg00238.html)
got worse in practice.

I think we can make it better in this specific case without solving it
in general, and doing it for html-mode would be a big win.

Roughly, I propose to add a rule in sgml-syntax-propertize-function that
would forcibly mark all angle brackets between <% and %> as punctuation
syntax. Testing it with

(with-silent-modifications
  (put-text-property (point) (1+ (point))
                     'syntax-table (string-to-syntax ".")))

seems to help both with highlighting and indentation.

Before I started writing this text, I had another approach in mind, but
this is something that I can probably do in mmm-mode instead, without
changing sgml-mode, by wrapping submodes' syntax-propertize-functions.
Still, doing it sgml-mode should be simpler.

Thoughts?





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

* bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags
  2013-03-20  3:36 bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags Dmitry Gutov
@ 2013-03-26 16:49 ` Stefan Monnier
  2013-04-01 13:32 ` Stefan Monnier
  1 sibling, 0 replies; 5+ messages in thread
From: Stefan Monnier @ 2013-03-26 16:49 UTC (permalink / raw)
  To: Dmitry Gutov; +Cc: 14003

> Roughly, I propose to add a rule in sgml-syntax-propertize-function that
> would forcibly mark all angle brackets between <% and %> as punctuation
> syntax. Testing it with

Sounds good.


        Stefan





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

* bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags
  2013-03-20  3:36 bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags Dmitry Gutov
  2013-03-26 16:49 ` Stefan Monnier
@ 2013-04-01 13:32 ` Stefan Monnier
  2013-04-01 20:43   ` Dmitry Gutov
  1 sibling, 1 reply; 5+ messages in thread
From: Stefan Monnier @ 2013-04-01 13:32 UTC (permalink / raw)
  To: Dmitry Gutov; +Cc: 14003

> Before I started writing this text, I had another approach in mind, but
> this is something that I can probably do in mmm-mode instead, without
> changing sgml-mode, by wrapping submodes' syntax-propertize-functions.
> Still, doing it sgml-mode should be simpler.
> Thoughts?

I agree doing it in sgml-mode would be simpler.

I do think that multi-major-mode support should let us handle
comments/strings in a separate mode (text-mode, by default).   But I'm
not sure if current multi-major-mode packages are up to that task.


        Stefan





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

* bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags
  2013-04-01 13:32 ` Stefan Monnier
@ 2013-04-01 20:43   ` Dmitry Gutov
  2013-04-03 18:25     ` Stefan Monnier
  0 siblings, 1 reply; 5+ messages in thread
From: Dmitry Gutov @ 2013-04-01 20:43 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: 14003-done

On 01.04.2013 17:32, Stefan Monnier wrote:
>> Before I started writing this text, I had another approach in mind, but
>> this is something that I can probably do in mmm-mode instead, without
>> changing sgml-mode, by wrapping submodes' syntax-propertize-functions.
>> Still, doing it sgml-mode should be simpler.
>> Thoughts?
>
> I agree doing it in sgml-mode would be simpler.

I've thought about it some more, and looks like it would be incompatible 
with what mmm-mode is currently doing. One of the latest additions is 
the composite syntax-propertize-function:

https://github.com/purcell/mmm-mode/blob/master/mmm-region.el#L806

It iterates over the regions and calls syntax-propertize-function of 
each major mode, passing it the bounds of the region. So adding 
propertization of angle brackets to sgml-syntax-propertize-function 
won't help because it won't be called on submode regions.

Wrapping propertize-functions of the submodes with that logic should 
work fine, though. So I guess I'll just close this bug.

> I do think that multi-major-mode support should let us handle
> comments/strings in a separate mode (text-mode, by default).   But I'm
> not sure if current multi-major-mode packages are up to that task.

Eh, maybe? With some caveats, probably, but delineating subregions based 
on string/comment status should be doable with a custom matcher 
function. But it doesn't seem to solve any big problems, AFAICT.

Handling code regions nested inside interpolated regions in strings, 
which I've posted about in emacs-devel before, would be nice to have, 
but it's much less of an immediate problem, especially since nobody uses 
this syntax feature of Ruby in real code much.

Handling it via mmm-mode, at least, is also problematic, because the 
syntactic state carries between subregions. So the text inside a string 
subregion will still be highlighted as string:

https://github.com/purcell/mmm-mode/issues/25





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

* bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags
  2013-04-01 20:43   ` Dmitry Gutov
@ 2013-04-03 18:25     ` Stefan Monnier
  0 siblings, 0 replies; 5+ messages in thread
From: Stefan Monnier @ 2013-04-03 18:25 UTC (permalink / raw)
  To: Dmitry Gutov; +Cc: 14003-done

>> I agree doing it in sgml-mode would be simpler.
> I've thought about it some more, and looks like it would be incompatible
> with what mmm-mode is currently doing.  One of the latest additions is the
> composite syntax-propertize-function:
> https://github.com/purcell/mmm-mode/blob/master/mmm-region.el#L806
> It iterates over the regions and calls syntax-propertize-function of each
> major mode, passing it the bounds of the region.  So adding propertization of
> angle brackets to sgml-syntax-propertize-function won't help because it
> won't be called on submode regions.

If don't use mmm-mode, then it should work.

But indeed when you use mmm-mode to handle the <%...%> text, then it
should be mmm-mode's task to handle that problem.


        Stefan "not saying that it's easy for mmm-mode to handle the problem"





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

end of thread, other threads:[~2013-04-03 18:25 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2013-03-20  3:36 bug#14003: 24.3.50; sgml-mode: support angle brackets inside jsp tags Dmitry Gutov
2013-03-26 16:49 ` Stefan Monnier
2013-04-01 13:32 ` Stefan Monnier
2013-04-01 20:43   ` Dmitry Gutov
2013-04-03 18:25     ` Stefan Monnier

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).