all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Philipp Stephani <p.stephani2@gmail.com>
To: Ivan Andrus <darthandrus@gmail.com>,
	Emacs developers <emacs-devel@gnu.org>
Cc: Eli Zaretskii <eliz@gnu.org>, Daniel Colascione <dancol@dancol.org>
Subject: Re: Callbacks from modules
Date: Thu, 26 Nov 2015 18:16:13 +0000	[thread overview]
Message-ID: <CAArVCkRqVLSau6gOhg6JFV861xXmRU3v-ExcNzoZNdCT3OEPqw@mail.gmail.com> (raw)
In-Reply-To: <EC6A6009-B909-4A5B-ACB2-94420E48AB9C@gmail.com>

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

Ivan Andrus <darthandrus@gmail.com> schrieb am Do., 26. Nov. 2015 um
07:09 Uhr:

> I’ve started writing an Emacs module to access NSSpeechSynthesizer on OS X
> (and maybe GNUStep though I haven’t tested it there).  I’ve been using the
> mod-test module as an example and I have it working reasonably well except
> that I don’t have any idea how to run a callback.
>
> When the synthesizer is done speaking it sends an Objective-C message
> speechSynthesizer:didFinishSpeaking.  From there I would like to run an
> elisp hook, say `ns-speech-finished-speaking-hook`.  How can I do this?  Do
> I have to squirrel away a pointer to an emacs_env somehow?  I tried naively
> storing env from a previous call but, not surprisingly, the pointer is
> invalid when I try to use it.
>
>
Yes, that is currently working as designed. Environments are alive only
while Emacs calls some module functions.

There are two major issues with allowing callbacks at arbitrary times,
which need to be discussed and resolved first. The first is that such a
facility would change the execution model of Emacs in a quite fundamental
way. Right now all user-defined code inside the Emacs process gets run
through a path under the control of Emacs, either as a response to an input
event, or a timer, or a process filter etc. Adding a facility to run module
code from arbitrary callbacks would remove this invariant, which can have
global effects on Emacs. With the current design modules are a pretty
localized feature: almost no other part of Emacs has to know about their
existence. If we allow callbacks at arbitrary times all parts of Emacs
would suddenly have to be prepared for this, and after decades of
development there might well be hidden assumptions that such things cannot
happen. Therefore I'd be very cautious before introducing such a facility.

The second issue is how such a facility should be made available. Currently
all communication between modules and Emacs happens through modules, and
there is no facility how modules can request creation of an environment.
However, it makes little sense to discuss this issue until the first one is
resolved.

[-- Attachment #2: Type: text/html, Size: 2478 bytes --]

  parent reply	other threads:[~2015-11-26 18:16 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-11-26  6:08 Callbacks from modules Ivan Andrus
2015-11-26 15:43 ` Eli Zaretskii
2015-11-26 16:17   ` joakim
2015-11-26 16:33     ` Eli Zaretskii
2015-11-26 17:01       ` Philipp Stephani
2015-11-26 17:19         ` Eli Zaretskii
2015-11-27  3:23   ` Ivan Andrus
2015-11-27  8:29     ` Eli Zaretskii
2015-11-27 17:30       ` Ivan Andrus
2015-11-26 18:16 ` Philipp Stephani [this message]
2015-11-26 18:41   ` Eli Zaretskii
2015-11-26 18:44     ` Philipp Stephani
2015-11-27  3:35       ` Ivan Andrus
2015-11-27  8:30         ` Eli Zaretskii
2015-11-27 17:31           ` Ivan Andrus
2015-11-27  4:22     ` Tom Tromey
2015-11-27  8:35       ` Eli Zaretskii
2015-11-30 14:03         ` Ted Zlatanov
2015-11-30 15:58           ` Eli Zaretskii
2015-11-30 16:52           ` John Wiegley
2015-11-27  4:20   ` Tom Tromey

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=CAArVCkRqVLSau6gOhg6JFV861xXmRU3v-ExcNzoZNdCT3OEPqw@mail.gmail.com \
    --to=p.stephani2@gmail.com \
    --cc=dancol@dancol.org \
    --cc=darthandrus@gmail.com \
    --cc=eliz@gnu.org \
    --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 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.