all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Eli Zaretskii <eliz@gnu.org>
To: "Jan Djärv" <jan.h.d@swipnet.se>
Cc: ofv@wanadoo.es, emacs-devel@gnu.org
Subject: Re: Emacs and Gnome Canvas
Date: Thu, 15 Jul 2010 13:24:04 +0300	[thread overview]
Message-ID: <83630hgi0r.fsf@gnu.org> (raw)
In-Reply-To: <4C3ED4F9.4080603@swipnet.se>

> Date: Thu, 15 Jul 2010 11:29:29 +0200
> From: Jan Djärv <jan.h.d@swipnet.se>
> CC: ofv@wanadoo.es, emacs-devel@gnu.org
> 
> > But the inserted character could be in the portion that is not
> > displayed at all, in which case it does not "require redisplay".  Who
> > should decide whether redisplay is necessary?  If that's Emacs, then
> > it should know a lot about the display layout.  If its the Canvas,
> > then it should know a lot about what portions of the buffer text are
> > on the screen.
> 
> You probably have your text in an CanvasItem that has a GtkTextBuffer.  When a 
> character is inserted, you insert in to the GtkTextBuffer.  The redisplay part 
> is then handeled internally between GtkTextBuffer, GnomeCanvas(Rich)TextItem 
> and GnomeCanvas.
> 
> As I said, it probably relies on having all text in the GtkTextBuffer.

But GtkTextBuffer needs text with attributes, right?  Currently, we
compute these attributes as part of redisplay, and only for the
displayed portion of the text.  Using GtkTextBuffer, it seems like we
will need to have a part (or an equivalent) of that redisplay code,
which would need to recompute the attributes for _all_ of the text,
after each modification of buffer text?  How can this be fast enough?
E.g., what if I'm viewing a large log file with non-trivial
fontification and clickable parts?

And what about redisplay optimizations?  For example, we now have a
special method that updates a window if the only change is that point
moved.  We don't care _why_ it moved -- there could be any number of
input events that cause this.  However, _determining_ that only point
moved is a non-trivial job, which examines about a dozen conditions on
some internal variables and flags.  Then there's another non-trivial
job: where on screen to move the cursor given the position of point.

If the communications with the Canvas is by means of a GtkTextBuffer,
how can these chores be done?  Won't we need to regenerate the
GtkTextBuffer, or at least its large parts, even when the only change
is point movement?

> >>>   How about an arbitrary mouse move?
> >>
> >> If it resulted in a different highlightning of a link, yes.
> >
> > Again, how to know that?  Note that some mouse movements perform
> > complex operations on Emacs objects, like popping up windows and
> > frames.
> 
> Each CanvasItem can have callbacks for mouse move, click, key press and so on. 
>   The idea is to have separate CanvasItems for the items that should react to 
> mouse events and then register callbacks for those events.  The callback then 
> pops up windows or whatever.

Which means running Lisp from redisplay, something we currently barely
support and generally discourage.

> It is a more event driven approach, and that in itself is a big modification 
> for Emacs which is more sequential in nature.

I understand the approach.  I'm trying to see how this approach can be
used without throwing most of the Emacs design out the window.




  reply	other threads:[~2010-07-15 10:24 UTC|newest]

Thread overview: 118+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-07-13 19:02 Emacs, QT and Cairo Was: Re: Efforts to attract more users? Stephen Eilert
2010-07-13 19:29 ` Chong Yidong
2010-07-13 19:51   ` Chad Brown
2010-07-13 20:48 ` Jan Djärv
2010-07-13 22:30   ` Emacs, QT and Cairo Chad Brown
2010-07-14  1:39     ` Stephen J. Turnbull
2010-07-14  2:32       ` Óscar Fuentes
2010-07-14  7:29     ` Eli Zaretskii
2010-07-14 18:37       ` Chad Brown
2010-07-14 20:45         ` Eli Zaretskii
2010-07-14 21:24           ` Óscar Fuentes
2010-07-15  6:55             ` Emacs and Gnome Canvas (was: Emacs, QT and Cairo) Eli Zaretskii
2010-07-15  7:46               ` Emacs and Gnome Canvas Jan Djärv
2010-07-15  7:53                 ` Jan Djärv
2010-07-15  8:36                   ` joakim
2010-07-15  8:40                   ` Eli Zaretskii
2010-07-15  8:50                     ` Jan Djärv
2010-07-15  8:38                 ` Eli Zaretskii
2010-07-15  8:48                   ` Jan Djärv
2010-07-15  8:59                     ` Eli Zaretskii
2010-07-15  9:29                       ` Jan Djärv
2010-07-15 10:24                         ` Eli Zaretskii [this message]
2010-07-15 10:54                           ` Jan Djärv
2010-07-15 12:27                             ` Eli Zaretskii
2010-07-15 14:18                               ` Óscar Fuentes
2010-07-15 15:14                                 ` Eli Zaretskii
2010-07-16  6:33                                   ` Miles Bader
2010-07-15 16:00                                 ` Chong Yidong
2010-07-15 16:27                                   ` Óscar Fuentes
2010-07-15 17:06                                     ` Eli Zaretskii
2010-07-15 17:48                                       ` Óscar Fuentes
2010-07-15 18:06                                         ` Eli Zaretskii
2010-07-15 21:27                                           ` Óscar Fuentes
2010-07-16  8:17                                             ` Eli Zaretskii
2010-07-16 14:24                                               ` Óscar Fuentes
2010-07-16 15:19                                                 ` Eli Zaretskii
2010-07-16 16:07                                                   ` Óscar Fuentes
2010-07-16 18:43                                                     ` Eli Zaretskii
2010-07-16 21:21                                                       ` Óscar Fuentes
2010-07-16 23:44                                                         ` Chad Brown
2010-07-17  0:08                                                           ` Óscar Fuentes
2010-07-17  7:57                                                             ` Eli Zaretskii
2010-07-17  8:34                                                               ` Andreas Schwab
2010-07-17  9:10                                                                 ` Eli Zaretskii
2010-07-17  9:40                                                                   ` Andreas Schwab
2010-07-17 10:23                                                                     ` Eli Zaretskii
2010-07-17 13:49                                                                       ` Óscar Fuentes
2010-07-17  7:27                                                         ` Eli Zaretskii
2010-07-17 13:42                                                           ` Óscar Fuentes
2010-07-17 15:27                                                             ` Eli Zaretskii
2010-07-17 21:53                                                               ` Óscar Fuentes
2010-07-18  1:42                                                               ` Miles Bader
2010-07-18  2:45                                                                 ` Óscar Fuentes
2010-07-18  8:06                                                                   ` Chad Brown
2010-07-18 14:43                                                                     ` Óscar Fuentes
2010-07-21  8:34                                                             ` Stefan Monnier
2010-07-22 14:26                                         ` Stefan Monnier
2010-07-15 17:22                                     ` Chong Yidong
2010-07-15 18:02                                       ` Óscar Fuentes
2010-07-15 22:10                                         ` Stephen Eilert
2010-07-16  7:52                                           ` Eli Zaretskii
2010-07-16  2:14                                   ` YAMAMOTO Mitsuharu
2010-07-16  7:33                                     ` Jan Djärv
2010-07-16  9:52                                       ` Eli Zaretskii
2010-07-16 10:15                                         ` YAMAMOTO Mitsuharu
2010-07-16 10:39                                           ` Eli Zaretskii
2010-07-16 12:42                                             ` Jan Djärv
2010-07-17  3:50                                               ` YAMAMOTO Mitsuharu
2010-07-17  8:33                                                 ` Jan Djärv
2010-07-17  8:38                                                   ` YAMAMOTO Mitsuharu
2010-07-17  9:18                                                     ` Jan Djärv
2010-07-17  9:25                                                       ` YAMAMOTO Mitsuharu
2010-07-17 10:26                                                         ` Jan Djärv
2010-07-18  3:51                                                           ` YAMAMOTO Mitsuharu
2010-07-18  7:10                                                             ` Jan Djärv
2010-07-18  7:45                                                               ` YAMAMOTO Mitsuharu
2010-07-18  9:06                                                                 ` Jan Djärv
2010-07-19  0:50                                                                   ` YAMAMOTO Mitsuharu
2010-07-17  1:00                                             ` YAMAMOTO Mitsuharu
2010-07-17  1:40                                               ` YAMAMOTO Mitsuharu
2010-07-17  8:04                                               ` Eli Zaretskii
2010-07-17  8:25                                                 ` YAMAMOTO Mitsuharu
2010-07-16 12:21                                         ` Jan Djärv
2010-07-16 10:01                                       ` YAMAMOTO Mitsuharu
2010-07-16 12:26                                         ` Jan Djärv
2010-07-16 14:05                                           ` Davis Herring
2010-07-16 17:38                                             ` Jan Djärv
2010-07-17  1:12                                               ` YAMAMOTO Mitsuharu
2010-07-17  7:14                                                 ` Eli Zaretskii
2010-07-17  7:31                                                   ` YAMAMOTO Mitsuharu
2010-07-17  8:12                                                     ` Eli Zaretskii
2010-07-17  8:32                                                       ` YAMAMOTO Mitsuharu
2010-07-15 14:24                               ` Jan Djärv
2010-07-15 14:35                                 ` Eli Zaretskii
2010-07-15 15:16                                   ` Jan Djärv
2010-07-15 15:20                                     ` Eli Zaretskii
2010-07-15 17:14                                       ` Jan Djärv
2010-07-15  9:20               ` Andy Wingo
2010-07-15 18:41               ` Emacs and Gnome Canvas (was: Emacs, QT and Cairo) Dirk-Jan C. Binnema
2010-07-15 21:51                 ` Emacs and Gnome Canvas Óscar Fuentes
2010-07-15 22:21                   ` Bruce Stephens
2010-07-27 21:24     ` Emacs, QT and Cairo Stefan Monnier
2010-07-27 21:36       ` Chad Brown
2010-07-28  3:05         ` Eli Zaretskii
2010-07-14  8:59 ` Emacs, QT and Cairo Was: Re: Efforts to attract more users? YAMAMOTO Mitsuharu
2010-07-14  9:41   ` Emacs, QT and Cairo David Engster
2010-07-14  9:56     ` Jan Djärv
2010-07-14 13:50     ` Drew Adams
2010-07-14 14:14       ` David Engster
2010-07-14 14:28         ` joakim
2010-07-14 15:41   ` Emacs, QT and Cairo Was: Re: Efforts to attract more users? Chong Yidong
2010-07-14 16:17     ` joakim
2010-07-14 18:04       ` Jan Djärv
2010-07-15 23:15 ` Andrew W. Nosenko
2010-07-16  7:41   ` Jan Djärv
2010-07-16 10:24     ` Andrew W. Nosenko
2010-07-16 12:36       ` Jan Djärv
  -- strict thread matches above, loose matches on Subject: below --
2010-07-17 19:02 Emacs and Gnome Canvas grischka

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

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

  git send-email \
    --in-reply-to=83630hgi0r.fsf@gnu.org \
    --to=eliz@gnu.org \
    --cc=emacs-devel@gnu.org \
    --cc=jan.h.d@swipnet.se \
    --cc=ofv@wanadoo.es \
    /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 external index

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

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.