From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Christopher Allan Webber Newsgroups: gmane.emacs.devel Subject: Re: Emacs Lisp's future Date: Fri, 10 Oct 2014 16:56:29 -0500 Message-ID: <87fvevzhsr.fsf@earlgrey.lan> References: <54193A70.9020901@member.fsf.org> <87lhp6h4zb.fsf@panthera.terpri.org> <87k34qo4c1.fsf@fencepost.gnu.org> <54257C22.2000806@yandex.ru> <83iokato6x.fsf@gnu.org> <87wq8pwjen.fsf@uwakimon.sk.tsukuba.ac.jp> <837g0ptnlj.fsf@gnu.org> <87r3yxwdr6.fsf@uwakimon.sk.tsukuba.ac.jp> <87tx3tmi3t.fsf@fencepost.gnu.org> <834mvttgsf.fsf@gnu.org> <87lhp5m99w.fsf@fencepost.gnu.org> <87h9ztm5oa.fsf@fencepost.gnu.org> <87d2ahm3nw.fsf@fencepost.gnu.org> <871tqneyvl.fsf@netris.org> <87lhonlks8.fsf@yeeloong.lan> NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: text/plain X-Trace: ger.gmane.org 1412979794 24586 80.91.229.3 (10 Oct 2014 22:23:14 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Fri, 10 Oct 2014 22:23:14 +0000 (UTC) Cc: dak@gnu.org, Richard Stallman , dmantipov@yandex.ru, emacs-devel@gnu.org, handa@gnu.org, monnier@iro.umontreal.ca, eliz@gnu.org, stephen@xemacs.org To: Mark H Weaver Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Sat Oct 11 00:23:07 2014 Return-path: Envelope-to: ged-emacs-devel@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1XciaY-0008FZ-NQ for ged-emacs-devel@m.gmane.org; Sat, 11 Oct 2014 00:23:06 +0200 Original-Received: from localhost ([::1]:51426 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1XciaY-0004ra-7t for ged-emacs-devel@m.gmane.org; Fri, 10 Oct 2014 18:23:06 -0400 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:52117) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1XciaG-0004rH-P0 for emacs-devel@gnu.org; Fri, 10 Oct 2014 18:22:53 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1XciaB-0003uN-SZ for emacs-devel@gnu.org; Fri, 10 Oct 2014 18:22:48 -0400 Original-Received: from dustycloud.org ([50.116.34.160]:60659) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Xcia0-0003mq-Kg; Fri, 10 Oct 2014 18:22:32 -0400 Original-Received: from earlgrey.lan (localhost [127.0.0.1]) by dustycloud.org (Postfix) with ESMTPS id 094572662F; Fri, 10 Oct 2014 18:22:29 -0400 (EDT) In-reply-to: <87lhonlks8.fsf@yeeloong.lan> X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 50.116.34.160 X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.devel:175241 Archived-At: Mark H Weaver writes: > Richard Stallman writes: > >> Supporting property lists in Scheme raises difficult questions >> >> Do you mean text properties in strings, as in Emacs Lisp? > > Yes. > > Having mulled it over, I've come to the conclusion that we can add text > properties to Guile strings without adding new security risks to > competently written Scheme code, with the following caveat: text > properties must be invisible to all existing Scheme procedures, > including 'equal?' and 'write'. > > However, as an exception to the caveat above, I think we can allow > existing Scheme string operations such as 'substring' and > 'string-append' to propagate the text properties. > > If you'd like to learn how I came to these conclusions, continue > reading, otherwise you can stop here. > > * * * > > Guile already supports weak-key (eq) hash tables, upon which we've > trivially implemented something called "object-properties": > > (define my-property (make-object-property)) > (set! (my-property ) 'foo) > (my-property ) => foo > > Effectively, this allows anyone to add a new private field to any > object. The new field is invisible to anything that doesn't know about > the object property, including equality predicates and all other > standard procedures. > > So we could use object-properties to add text properties to Guile > strings. Therefore, we can regard it as a mere efficiency hack to add a > new field to our string objects, as long as the semantics are the same > as if the new field was an object-property. > > However, this still leaves open the question of whether *propagating* > these text properties to newly-allocated strings (by 'substring', > 'string-append', etc) adds new risks. > > This next step makes me a bit uneasy, but I think it will also be okay, > because standard Scheme does not require 'eq?' to be usable on > characters, i.e. it does not require characters to be immediates or even > interned. > > This means that we could, in principle, use object-properties to > associate text properties with the characters themselves, instead of > with the string objects. This would quite naturally lead to them being > copied by string operations such as 'substring' and 'string-append'. > > Therefore, it seems to me that adding text properties to Guile strings > does not add any security issues that are not already present in > standard Scheme. > > What do you think? > > Mark It sounds, if I am reading this right, that the mechanism by which properties are being added to scheme strings means that no actual changes need to be made to Guile strings' datastructures. If true, that sounds like a very efficient and ideal solution because it is so generic. In fact, I gave it a whirl... you mean something like this? (define elisp-properties (make-object-property)) (define (elisp-propertize string . args) (let ((copied-string (string-copy string))) (set! (elisp-properties copied-string) args) copied-string)) (define my-monkey (elisp-propertize "monkey" 'eats 'bananas)) ;; => "monkey" (elisp-properties my-monkey) ;; => (eats bananas) That's awesome! And it doesn't feel like we're changing Guile in any core way just to accomodate elisp, and it seems bidirectionally compatible... But as for copying around property lists when copying strings, making substrings, etc, I think I'm more uncomfortable with that idea using default Guile methods. That seems like changing the language in a substantial way that may even have strange performance issues or unexpected side effects... would we do such a thing if this were anything other than Emacs? Would we do it for Javascript? But it doesn't seem to me like we need to worry: why not just add a library like this: (use-module (language elisp string-tools)) (elisp-substring (elisp-propertize "monkeys" 'eat 'bananas) 3 6) ;; => this would return "key", but with object properties of ;; (eat bananas) (elisp-substring "monkeys" 3 6) ;; => this would return "key", but with no object properties (elisp-substring (elisp-propertize "monkeys" 'eat 'bananas) 3 6) ;; => this would return "key" with no object properties The version of substring provided in emacs lisp would of course be elisp-substring, and strings would work between guile and emacs, but as for copying around strings with properties, only functions in guile which care about this would have to deal with it and deal with any related concerns. - Chris