unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
* Working with constansts
@ 2009-05-10 15:25 Decebal
  2009-05-10 16:19 ` Pascal J. Bourguignon
  2009-05-10 16:31 ` Drew Adams
  0 siblings, 2 replies; 28+ messages in thread
From: Decebal @ 2009-05-10 15:25 UTC (permalink / raw)
  To: help-gnu-emacs

I would like to work with constants in my elisp code. I thought that I
could do this with defconst, but that doen not work.
After:
    (defconst dummy "testing")
The variable dummy has the value "testing".
But after:
    (setq dummy "changed")
The variable dummy has the value "changed".
What am I doing wrong.
I am working with 'myself compiled Emacs 22.3.


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

* Re: Working with constansts
  2009-05-10 15:25 Working with constansts Decebal
@ 2009-05-10 16:19 ` Pascal J. Bourguignon
  2009-05-10 16:20   ` Richard Riley
  2009-05-11  8:27   ` Decebal
  2009-05-10 16:31 ` Drew Adams
  1 sibling, 2 replies; 28+ messages in thread
From: Pascal J. Bourguignon @ 2009-05-10 16:19 UTC (permalink / raw)
  To: help-gnu-emacs

Decebal <CLDWesterhof@gmail.com> writes:

> I would like to work with constants in my elisp code. I thought that I
> could do this with defconst, but that doen not work.
> After:
>     (defconst dummy "testing")
> The variable dummy has the value "testing".
> But after:
>     (setq dummy "changed")
> The variable dummy has the value "changed".
> What am I doing wrong.

You're still thinking that constants don't change or that variables do.

If you don't want to change the value of a constant, then don't change it.

-- 
__Pascal Bourguignon__


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

* Re: Working with constansts
  2009-05-10 16:19 ` Pascal J. Bourguignon
@ 2009-05-10 16:20   ` Richard Riley
  2009-05-10 16:33     ` Pascal J. Bourguignon
                       ` (3 more replies)
  2009-05-11  8:27   ` Decebal
  1 sibling, 4 replies; 28+ messages in thread
From: Richard Riley @ 2009-05-10 16:20 UTC (permalink / raw)
  To: help-gnu-emacs

pjb@informatimago.com (Pascal J. Bourguignon) writes:

> Decebal <CLDWesterhof@gmail.com> writes:
>
>> I would like to work with constants in my elisp code. I thought that I
>> could do this with defconst, but that doen not work.
>> After:
>>     (defconst dummy "testing")
>> The variable dummy has the value "testing".
>> But after:
>>     (setq dummy "changed")
>> The variable dummy has the value "changed".
>> What am I doing wrong.
>
> You're still thinking that constants don't change or that variables do.
>
> If you don't want to change the value of a constant, then don't change
> it.

Why is it called a constant if its not enforced?


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

* RE: Working with constansts
  2009-05-10 15:25 Working with constansts Decebal
  2009-05-10 16:19 ` Pascal J. Bourguignon
@ 2009-05-10 16:31 ` Drew Adams
  1 sibling, 0 replies; 28+ messages in thread
From: Drew Adams @ 2009-05-10 16:31 UTC (permalink / raw)
  To: 'Decebal', help-gnu-emacs

> I would like to work with constants in my elisp code. I thought that I
> could do this with defconst, but that doen not work.
> After: (defconst dummy "testing")
> The variable dummy has the value "testing".
> But after: (setq dummy "changed")
> The variable dummy has the value "changed".
> What am I doing wrong.

From the Elisp manual:

"The difference between `defconst' and `defvar' is primarily a matter
of intent, serving to inform human readers of whether the value should
ever change.  Emacs Lisp does not restrict the ways in which a variable
can be used based on `defconst' or `defvar' declarations.  However, it
does make a difference for initialization: `defconst' unconditionally
initializes the variable, while `defvar' initializes it only if it is
void."

Nothing prevents a user or program from changing the value of a `defconst'
variable. Unless you somehow cripple Emacs Lisp, you can always find a way to
modify something. That's about the only constant. ;-)





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

* Re: Working with constansts
  2009-05-10 16:20   ` Richard Riley
@ 2009-05-10 16:33     ` Pascal J. Bourguignon
  2009-05-12 10:34       ` Nikolaj Schumacher
  2009-05-10 17:02     ` Drew Adams
                       ` (2 subsequent siblings)
  3 siblings, 1 reply; 28+ messages in thread
From: Pascal J. Bourguignon @ 2009-05-10 16:33 UTC (permalink / raw)
  To: help-gnu-emacs

Richard Riley <rileyrgdev@googlemail.com> writes:

> pjb@informatimago.com (Pascal J. Bourguignon) writes:
>
>> Decebal <CLDWesterhof@gmail.com> writes:
>>
>>> I would like to work with constants in my elisp code. I thought that I
>>> could do this with defconst, but that doen not work.
>>> After:
>>>     (defconst dummy "testing")
>>> The variable dummy has the value "testing".
>>> But after:
>>>     (setq dummy "changed")
>>> The variable dummy has the value "changed".
>>> What am I doing wrong.
>>
>> You're still thinking that constants don't change or that variables do.
>>
>> If you don't want to change the value of a constant, then don't change
>> it.
>
> Why is it called a constant if its not enforced?

For example we call PI a constant.  But PI is the ration between a
circle circumference and its diameter, and this ratio depends on the
curvature of the universe, so PI is not really a constant: in our
universe it depends on the altitude, or the distance to the sun, (on
the gravity in general).

So if you want to avoid bugs in your emacs program when you travel,
you must be able to nudge the values of the constants.  


-- 
__Pascal Bourguignon__


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

* RE: Working with constansts
  2009-05-10 16:20   ` Richard Riley
  2009-05-10 16:33     ` Pascal J. Bourguignon
@ 2009-05-10 17:02     ` Drew Adams
  2009-05-10 17:28       ` Richard Riley
       [not found]       ` <mailman.6953.1241976532.31690.help-gnu-emacs@gnu.org>
  2009-05-11  9:58     ` Thien-Thi Nguyen
       [not found]     ` <mailman.6988.1242036217.31690.help-gnu-emacs@gnu.org>
  3 siblings, 2 replies; 28+ messages in thread
From: Drew Adams @ 2009-05-10 17:02 UTC (permalink / raw)
  To: 'Richard Riley', help-gnu-emacs

> Why is it called a constant if its not enforced?

As the doc says (explicitly): to signal programmer *intention*. It lets human
readers of the code know that it is *intended* that no one and no code will
change the value. Think of it as a comment to that effect, if you like: "Do not
change this value."

Coding with clear signals of intention is helpful, and too often overlooked.
Conventional distinctions of intention among `defconst' vs `defvar'; `when' and
`unless' vs `if' and `cond' vs `and' and `or'; and so on can make a big
difference in code legibility. Which in turn eases maintenance and makes it less
error-prone.

Likewise, wrt names of functions, variables, etc.: good names help maintainers
and code borrowers. Likewise, comments - good ones. Likewise, indenting and
whitespace generally.

All of these things are for human readers of code only. You, like the Lisp
reader, can do without them if you like. YMMV.

[I knew an excellent (in individual terms) Lisp programmer back in the 80s who
never used any whitespace that wasn't strictly needed for the Lisp reader and
never commented any code. He (almost) never hit the Return key. Needless to say,
no one else could work with his code. He did use reasonable names, however, and
he didn't use the same conditional (e.g. `if' or `cond') everywhere. He coded in
the way that was easiest to him and that got the point across to the Lisp
reader.]

Perhaps you have another question:
Q. Why isn't it enforced?  A. Lisp.





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

* Re: Working with constansts
  2009-05-10 17:02     ` Drew Adams
@ 2009-05-10 17:28       ` Richard Riley
  2009-05-11  7:39         ` Tassilo Horn
       [not found]       ` <mailman.6953.1241976532.31690.help-gnu-emacs@gnu.org>
  1 sibling, 1 reply; 28+ messages in thread
From: Richard Riley @ 2009-05-10 17:28 UTC (permalink / raw)
  To: Drew Adams; +Cc: help-gnu-emacs, 'Richard Riley'

"Drew Adams" <drew.adams@oracle.com> writes:

>> Why is it called a constant if its not enforced?
>
> As the doc says (explicitly): to signal programmer *intention*. It lets human
> readers of the code know that it is *intended* that no one and no code will
> change the value. Think of it as a comment to that effect, if you like: "Do not
> change this value."
>
> Coding with clear signals of intention is helpful, and too often overlooked.
> Conventional distinctions of intention among `defconst' vs `defvar'; `when' and
> `unless' vs `if' and `cond' vs `and' and `or'; and so on can make a big
> difference in code legibility. Which in turn eases maintenance and makes it less
> error-prone.

No two ways. I agree.

>
> Likewise, wrt names of functions, variables, etc.: good names help maintainers
> and code borrowers. Likewise, comments - good ones. Likewise, indenting and
> whitespace generally.
>
> All of these things are for human readers of code only. You, like the Lisp
> reader, can do without them if you like. YMMV.

I don't think anyone would disagree. But this is really a lecture on
clear, structured programming for beginners and not really that
relevant to the specifics of LISP constants in question.

>
> [I knew an excellent (in individual terms) Lisp programmer back in the 80s who
> never used any whitespace that wasn't strictly needed for the Lisp reader and
> never commented any code. He (almost) never hit the Return key. Needless to say,
> no one else could work with his code. He did use reasonable names, however, and
> he didn't use the same conditional (e.g. `if' or `cond') everywhere. He coded in
> the way that was easiest to him and that got the point across to the Lisp
> reader.]

He sounds like a terrible programmer. Programmers that write for
themselves are a curse. Maintenance time exceeds initial development
time by factors of 10 or 100 in most cases.

>
> Perhaps you have another question:
> Q. Why isn't it enforced?  A. Lisp.
>

Not really. It's not a constant. Having the specific type and then being
able to modify it proves that. You would be as well sticking CONST as the
name prefix as far as the language goes. As clear.

But yes, of course I agree with your comments on "intent". But it
strikes me that its no more effective than, say requiring a file called
"myconstants" that has a bunch of variables.

So really the question would be : why does Lisp not enforce constants
being, err, constant? 





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

* Re: Working with constansts
       [not found]       ` <mailman.6953.1241976532.31690.help-gnu-emacs@gnu.org>
@ 2009-05-10 18:17         ` Pascal J. Bourguignon
  2009-05-11  1:36           ` Richard Riley
  2009-05-10 18:59         ` Barry Margolin
  1 sibling, 1 reply; 28+ messages in thread
From: Pascal J. Bourguignon @ 2009-05-10 18:17 UTC (permalink / raw)
  To: help-gnu-emacs

Richard Riley <rileyrgdev@googlemail.com> writes:
>> [I knew an excellent (in individual terms) Lisp programmer back in the 80s who
>> never used any whitespace that wasn't strictly needed for the Lisp reader and
>> never commented any code. He (almost) never hit the Return key. Needless to say,
>> no one else could work with his code. He did use reasonable names, however, and
>> he didn't use the same conditional (e.g. `if' or `cond') everywhere. He coded in
>> the way that was easiest to him and that got the point across to the Lisp
>> reader.]
>
> He sounds like a terrible programmer. Programmers that write for
> themselves are a curse. Maintenance time exceeds initial development
> time by factors of 10 or 100 in most cases.

pprint. To me he sounds like a very good programmer. There's no point
in doing something that a simple function can do for you...


>> Perhaps you have another question:
>> Q. Why isn't it enforced?  A. Lisp.
>>
>
> Not really. It's not a constant. Having the specific type and then being
> able to modify it proves that. You would be as well sticking CONST as the
> name prefix as far as the language goes. As clear.
>
> But yes, of course I agree with your comments on "intent". But it
> strikes me that its no more effective than, say requiring a file called
> "myconstants" that has a bunch of variables.
>
> So really the question would be : why does Lisp not enforce constants
> being, err, constant? 


In the case of emacs lisp, it's because the constant is still refered
to, even in compiled code, thru the constant name.  So if the value
bound to the symbol change, it will change instantaneously for all the
functions that us it.

If you consider that emacs is usually a long running process that the
user is continuously modifying, it's rather a good thing: it means you
don't have to recompile everything when you correct the value of a
constant.



But you asked about Lisp.


We'd have to do a study of the numerous remaining lisp dialects still
in existance, but to take the example of Common Lisp, its standard
specifies that you shouldn't modify the value of a constant, and that
implementations are free to do whatever they want if you do.  Indeed,
some implementation behave like emacs lisp (eg. clisp, which has
basically the same architecture as emacs lisp: both use a virtual
machine and a byte code compiler).  On the other hand, in the case of
sbcl, which uses a native code compiler, the constants are inlined and
if you change them, it won't recompile automatically the code that
depend on them, so you may get inconsistencies.  But it doesn't
matter, since you shouldn't do that anyways.  If you really want to
change the value of a constant, you should recompile your system and
reload it. (Or else, don't use constants, so the new value of
variables may be taken into account immediately without
recompilation).


-- 
__Pascal Bourguignon__


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

* Re: Working with constansts
       [not found]       ` <mailman.6953.1241976532.31690.help-gnu-emacs@gnu.org>
  2009-05-10 18:17         ` Pascal J. Bourguignon
@ 2009-05-10 18:59         ` Barry Margolin
  2009-05-11  1:38           ` Richard Riley
  1 sibling, 1 reply; 28+ messages in thread
From: Barry Margolin @ 2009-05-10 18:59 UTC (permalink / raw)
  To: help-gnu-emacs

In article <mailman.6953.1241976532.31690.help-gnu-emacs@gnu.org>,
 Richard Riley <rileyrgdev@googlemail.com> wrote:

> So really the question would be : why does Lisp not enforce constants
> being, err, constant? 

Because this would incur overhead on every assignment, as it would have 
to check whether the variable being assigned was declared as a constant.  
Since this is so rarely the case, this overhead could be seen as mostly 
wasted and unnecessary.

On the other hand, it would be nice if the byte compiler would warn 
about this.  Declaring a constant could put something in its property 
list, and the compiler could then warn if it sees assignments to the 
variable.

Some Common Lisp implementations get around the overhead problem by 
putting constants in a page of VM marked read-only, so a hardware trap 
is raised if an attempt is made to assign it.

-- 
Barry Margolin, barmar@alum.mit.edu
Arlington, MA
*** PLEASE post questions in newsgroups, not directly to me ***
*** PLEASE don't copy me on replies, I'll read them in the group ***


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

* Re: Working with constansts
  2009-05-10 18:17         ` Pascal J. Bourguignon
@ 2009-05-11  1:36           ` Richard Riley
  2009-05-11  6:29             ` Pascal J. Bourguignon
  0 siblings, 1 reply; 28+ messages in thread
From: Richard Riley @ 2009-05-11  1:36 UTC (permalink / raw)
  To: help-gnu-emacs

pjb@informatimago.com (Pascal J. Bourguignon) writes:

> Richard Riley <rileyrgdev@googlemail.com> writes:
>>> [I knew an excellent (in individual terms) Lisp programmer back in the 80s who
>>> never used any whitespace that wasn't strictly needed for the Lisp reader and
>>> never commented any code. He (almost) never hit the Return key. Needless to say,
>>> no one else could work with his code. He did use reasonable names, however, and
>>> he didn't use the same conditional (e.g. `if' or `cond') everywhere. He coded in
>>> the way that was easiest to him and that got the point across to the Lisp
>>> reader.]
>>
>> He sounds like a terrible programmer. Programmers that write for
>> themselves are a curse. Maintenance time exceeds initial development
>> time by factors of 10 or 100 in most cases.
>
> pprint. To me he sounds like a very good programmer. There's no point
> in doing something that a simple function can do for you...

Hold on.

I agree with concise and clean code.

But blatant showing off with NO whitespace or use of return code is the
sign of, frankly, a loony.



>
>
>>> Perhaps you have another question:
>>> Q. Why isn't it enforced?  A. Lisp.
>>>
>>
>> Not really. It's not a constant. Having the specific type and then being
>> able to modify it proves that. You would be as well sticking CONST as the
>> name prefix as far as the language goes. As clear.
>>
>> But yes, of course I agree with your comments on "intent". But it
>> strikes me that its no more effective than, say requiring a file called
>> "myconstants" that has a bunch of variables.
>>
>> So really the question would be : why does Lisp not enforce constants
>> being, err, constant? 
>
>
> In the case of emacs lisp, it's because the constant is still refered
> to, even in compiled code, thru the constant name.  So if the value
> bound to the symbol change, it will change instantaneously for all the
> functions that us it.
>
> If you consider that emacs is usually a long running process that the
> user is continuously modifying, it's rather a good thing: it means you
> don't have to recompile everything when you correct the value of a
> constant.
>
>
>
> But you asked about Lisp.
>
>
> We'd have to do a study of the numerous remaining lisp dialects still
> in existance, but to take the example of Common Lisp, its standard
> specifies that you shouldn't modify the value of a constant, and that
> implementations are free to do whatever they want if you do.  Indeed,
> some implementation behave like emacs lisp (eg. clisp, which has
> basically the same architecture as emacs lisp: both use a virtual
> machine and a byte code compiler).  On the other hand, in the case of
> sbcl, which uses a native code compiler, the constants are inlined and
> if you change them, it won't recompile automatically the code that
> depend on them, so you may get inconsistencies.  But it doesn't
> matter, since you shouldn't do that anyways.  If you really want to
> change the value of a constant, you should recompile your system and
> reload it. (Or else, don't use constants, so the new value of
> variables may be taken into account immediately without
> recompilation).

Which was basically my original question.

If you go to the bother of having a "const xyz" implementation then it
seems to me slightly silly not to enforce it.

Of course I understand if the answer is "history and that's the way it
is" but I would sympathise with a new programmer to Lisp that is
surprised he can modify a "const" especially if he came from a C/C++
background where we all fully understand WHY consts are useful for the
programmer but the compiler also enforced it.


-- 


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

* Re: Working with constansts
  2009-05-10 18:59         ` Barry Margolin
@ 2009-05-11  1:38           ` Richard Riley
  2009-05-12  9:44             ` Nikolaj Schumacher
       [not found]             ` <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>
  0 siblings, 2 replies; 28+ messages in thread
From: Richard Riley @ 2009-05-11  1:38 UTC (permalink / raw)
  To: help-gnu-emacs

Barry Margolin <barmar@alum.mit.edu> writes:

> In article <mailman.6953.1241976532.31690.help-gnu-emacs@gnu.org>,
>  Richard Riley <rileyrgdev@googlemail.com> wrote:
>
>> So really the question would be : why does Lisp not enforce constants
>> being, err, constant? 
>
> Because this would incur overhead on every assignment, as it would have 
> to check whether the variable being assigned was declared as a constant.  
> Since this is so rarely the case, this overhead could be seen as mostly 
> wasted and unnecessary.

I don't know enough about Lisp than I can only assume that in this case
it can not be detected at compile time IF you compile to byte/p code.

>
> On the other hand, it would be nice if the byte compiler would warn 
> about this.  Declaring a constant could put something in its property 
> list, and the compiler could then warn if it sees assignments to the 
> variable.
>
> Some Common Lisp implementations get around the overhead problem by 
> putting constants in a page of VM marked read-only, so a hardware trap 
> is raised if an attempt is made to assign it.

This makes sense. My initial enquiry was kind of "yeah, thats the way
you say it is, but should it really be like that". If you get my drift.


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

* Re: Working with constansts
  2009-05-11  1:36           ` Richard Riley
@ 2009-05-11  6:29             ` Pascal J. Bourguignon
  2009-05-12 10:06               ` Nikolaj Schumacher
       [not found]               ` <mailman.7056.1242122790.31690.help-gnu-emacs@gnu.org>
  0 siblings, 2 replies; 28+ messages in thread
From: Pascal J. Bourguignon @ 2009-05-11  6:29 UTC (permalink / raw)
  To: help-gnu-emacs

Richard Riley <rileyrgdev@googlemail.com> writes:

> Which was basically my original question.
>
> If you go to the bother of having a "const xyz" implementation then it
> seems to me slightly silly not to enforce it.
>
> Of course I understand if the answer is "history and that's the way it
> is" but I would sympathise with a new programmer to Lisp that is
> surprised he can modify a "const" especially if he came from a C/C++
> background where we all fully understand WHY consts are useful for the
> programmer but the compiler also enforced it.

The important point is that a lisp system is being programmed at the
same time it is executed.  Therefore redefining a constant may be
taken into account, because it may be what the _programmer_ really
means.

In C, you would have to recompile the program before a change to a
constant is taken into account, but it would be very possible to
modify a constant: nothing prevents you to edit the C sources,
recompile and relaunch.

Some lisps (such as SBCL) do indeed issue a warning (actually a
continuable error) when you try to change a constant.




Usually, we apply a convention of naming constants surrounding them
with + signs:

   (defconst +xyz+ 42)

so you notice immediately if you're doing something you don't mean
when you write:

   (setq +xyz+ ...)

This low-tech solution is good enough, so there's no much point in
implementing further tests in the implementation.

(But unfortunately, these conventions are not often respected in emacs
lisp code).  
-- 
__Pascal Bourguignon__


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

* Re: Working with constansts
  2009-05-10 17:28       ` Richard Riley
@ 2009-05-11  7:39         ` Tassilo Horn
  0 siblings, 0 replies; 28+ messages in thread
From: Tassilo Horn @ 2009-05-11  7:39 UTC (permalink / raw)
  To: help-gnu-emacs

Richard Riley <rileyrgdev@googlemail.com> writes:

Hi Richard,

> So really the question would be : why does Lisp not enforce constants
> being, err, constant?

I think it has something to do how lisp programs can be maintained.
What looks like a constant today may change in the future (maybe by
something totally unrelated like a new law).  With java for example, you
would change that constant in the code, rebuild and restart the
application.  With lisp you go to the repl and simply change the
constant without having to restart anything.

So you see that enforcing immutability of constants has drawbacks, too.
But the emacs byte-compiler issues a warning instead:

,----[ ~/test.el ]
| (defconst test-constant "CONSTANT")
| (setq test-constant "CHANGED")
`----

--8<---------------cut here---------------start------------->8---
% emacs -Q --batch -f batch-byte-compile test.el 
In toplevel form:
test.el:3:7:Warning: variable assignment to constant `test-constant'
Wrote /home/horn/test.elc
--8<---------------cut here---------------end--------------->8---

Bye,
Tassilo
-- 
Chuck Norris once rode a bull, and nine months later it had a calf. 





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

* Re: Working with constansts
  2009-05-10 16:19 ` Pascal J. Bourguignon
  2009-05-10 16:20   ` Richard Riley
@ 2009-05-11  8:27   ` Decebal
  2009-05-12  9:46     ` Nikolaj Schumacher
  1 sibling, 1 reply; 28+ messages in thread
From: Decebal @ 2009-05-11  8:27 UTC (permalink / raw)
  To: help-gnu-emacs

On May 10, 6:19 pm, p...@informatimago.com (Pascal J. Bourguignon)
wrote:
> Decebal <CLDWester...@gmail.com> writes:
> > I would like to work with constants in my elisp code. I thought that I
> > could do this with defconst, but that doen not work.
> > After:
> >     (defconst dummy "testing")
> > The variable dummy has the value "testing".
> > But after:
> >     (setq dummy "changed")
> > The variable dummy has the value "changed".
> > What am I doing wrong.
>
> You're still thinking that constants don't change or that variables do.
>
> If you don't want to change the value of a constant, then don't change it.

But if I make a library and distribute it, the receiver could -
unwittingly- change it. But the idea of using '+' to put before and
after the variable name is a good one. I'll do that.

By the way: you can only change sources if you have them. ;-]
Also: changing a source and recompiling is a little bit more obvious -
also for the person doing it- as a setq.

But my understanding of elisp has been amended. That never hurts.


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

* Re: Working with constansts
  2009-05-10 16:20   ` Richard Riley
  2009-05-10 16:33     ` Pascal J. Bourguignon
  2009-05-10 17:02     ` Drew Adams
@ 2009-05-11  9:58     ` Thien-Thi Nguyen
       [not found]     ` <mailman.6988.1242036217.31690.help-gnu-emacs@gnu.org>
  3 siblings, 0 replies; 28+ messages in thread
From: Thien-Thi Nguyen @ 2009-05-11  9:58 UTC (permalink / raw)
  To: help-gnu-emacs

() Richard Riley <rileyrgdev@googlemail.com>
() Sun, 10 May 2009 18:20:54 +0200

   Why is it called a constant if its not enforced?

Who calls it constant?  Does Emacs call it constant?

thi




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

* Re: Working with constansts
       [not found]     ` <mailman.6988.1242036217.31690.help-gnu-emacs@gnu.org>
@ 2009-05-12  1:31       ` Barry Margolin
  0 siblings, 0 replies; 28+ messages in thread
From: Barry Margolin @ 2009-05-12  1:31 UTC (permalink / raw)
  To: help-gnu-emacs

In article <mailman.6988.1242036217.31690.help-gnu-emacs@gnu.org>,
 Thien-Thi Nguyen <ttn@gnuvola.org> wrote:

> () Richard Riley <rileyrgdev@googlemail.com>
> () Sun, 10 May 2009 18:20:54 +0200
> 
>    Why is it called a constant if its not enforced?
> 
> Who calls it constant?  Does Emacs call it constant?

From C-h f defconst: "Define symbol as a constant variable."

Of course, "constant variable" is a notorious oxymoron.

-- 
Barry Margolin, barmar@alum.mit.edu
Arlington, MA
*** PLEASE post questions in newsgroups, not directly to me ***
*** PLEASE don't copy me on replies, I'll read them in the group ***


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

* Re: Working with constansts
  2009-05-11  1:38           ` Richard Riley
@ 2009-05-12  9:44             ` Nikolaj Schumacher
       [not found]             ` <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>
  1 sibling, 0 replies; 28+ messages in thread
From: Nikolaj Schumacher @ 2009-05-12  9:44 UTC (permalink / raw)
  To: Richard Riley; +Cc: help-gnu-emacs

Richard Riley <rileyrgdev@googlemail.com> wrote:

>> Because this would incur overhead on every assignment, as it would have 
>> to check whether the variable being assigned was declared as a constant.  
>> Since this is so rarely the case, this overhead could be seen as mostly 
>> wasted and unnecessary.
>
> I don't know enough about Lisp than I can only assume that in this case
> it can not be detected at compile time IF you compile to byte/p code.

"Thanks" to dynamic scoping it cannot be caught at compile time.

(defconst xxx nil)

(defun change-xxx ()
  (setx xxx t)) ;; const or variable?

(let ((xxx nil))
  (change-xxx))


regards,
Nikolaj Schumacher




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

* Re: Working with constansts
  2009-05-11  8:27   ` Decebal
@ 2009-05-12  9:46     ` Nikolaj Schumacher
  0 siblings, 0 replies; 28+ messages in thread
From: Nikolaj Schumacher @ 2009-05-12  9:46 UTC (permalink / raw)
  To: Decebal; +Cc: help-gnu-emacs

Decebal <CLDWesterhof@gmail.com> wrote:

> But if I make a library and distribute it, the receiver could -
> unwittingly- change it. But the idea of using '+' to put before and
> after the variable name is a good one. I'll do that.

What about your internal variables?  The user is probably not supposed
to unwittingly change them, either.  So the problem isn't limited to
constants.  It's Elisp's complete lack of data-hiding.

The proper way to mark a variable as user-changeable is to start the
docstring with a "*".  To mark variables (or consts) as "private", it
has become somewhat common to use a double dash like prefix--value
instead of prefix-value.



regards,
Nikolaj Schumacher




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

* Re: Working with constansts
  2009-05-11  6:29             ` Pascal J. Bourguignon
@ 2009-05-12 10:06               ` Nikolaj Schumacher
       [not found]               ` <mailman.7056.1242122790.31690.help-gnu-emacs@gnu.org>
  1 sibling, 0 replies; 28+ messages in thread
From: Nikolaj Schumacher @ 2009-05-12 10:06 UTC (permalink / raw)
  To: Pascal J. Bourguignon; +Cc: help-gnu-emacs

pjb@informatimago.com (Pascal J. Bourguignon) wrote:

> Richard Riley <rileyrgdev@googlemail.com> writes:
>
>> Of course I understand if the answer is "history and that's the way it
>> is" but I would sympathise with a new programmer to Lisp that is
>> surprised he can modify a "const" especially if he came from a C/C++
>> background where we all fully understand WHY consts are useful for the
>> programmer but the compiler also enforced it.
>
> The important point is that a lisp system is being programmed at the
> same time it is executed.  Therefore redefining a constant may be
> taken into account, because it may be what the _programmer_ really
> means.
>
> In C, you would have to recompile the program before a change to a
> constant is taken into account, but it would be very possible to
> modify a constant: nothing prevents you to edit the C sources,
> recompile and relaunch.

Certainly const in C doesn't mean the value is determined at compile
time.  It just means: "This variable shouldn't be modified after its
initialization."

And in fact, you can cast constness away in C++, so it really has
nothing to do with execution versus compile time.  It's just a helper
for the developer to prevent side-effects.

There really is no pressing requirement for the current behavior, the
run-time just doesn't verify it.  It does one thing, though:

(setq xxx 'user)
(defvar xxx 'library)
xxx => 'user

(setq xxx 'user)
(defconst xxx 'library)
xxx => 'library

A tiny step towards enforcing the value.


regards,
Nikolaj Schumacher




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

* Re: Working with constansts
  2009-05-10 16:33     ` Pascal J. Bourguignon
@ 2009-05-12 10:34       ` Nikolaj Schumacher
  0 siblings, 0 replies; 28+ messages in thread
From: Nikolaj Schumacher @ 2009-05-12 10:34 UTC (permalink / raw)
  To: Pascal J. Bourguignon; +Cc: help-gnu-emacs


> For example we call PI a constant.  But PI is the ration between a
> circle circumference and its diameter, and this ratio depends on the
> curvature of the universe, so PI is not really a constant: in our
> universe it depends on the altitude, or the distance to the sun, (on
> the gravity in general).

Certainly PI is a real constant.  It is not defined by relative
physical properties, but my mathematics.  (In the physical universe,
there is no such thing as a circle.[1])

Yes, when physicists use the word "constant", it's actually an
assumption or average measurement.  But code is mathematics, not physics.


regards,
Nikolaj Schumacher

[1]: probably




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

* Re: Working with constansts
       [not found]             ` <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>
@ 2009-05-12 11:43               ` Pascal J. Bourguignon
  2009-05-13  4:59               ` Barry Margolin
  1 sibling, 0 replies; 28+ messages in thread
From: Pascal J. Bourguignon @ 2009-05-12 11:43 UTC (permalink / raw)
  To: help-gnu-emacs

Nikolaj Schumacher <me@nschum.de> writes:

> Richard Riley <rileyrgdev@googlemail.com> wrote:
>
>>> Because this would incur overhead on every assignment, as it would have 
>>> to check whether the variable being assigned was declared as a constant.  
>>> Since this is so rarely the case, this overhead could be seen as mostly 
>>> wasted and unnecessary.
>>
>> I don't know enough about Lisp than I can only assume that in this case
>> it can not be detected at compile time IF you compile to byte/p code.
>
> "Thanks" to dynamic scoping it cannot be caught at compile time.
>
> (defconst xxx nil)
>
> (defun change-xxx ()
>   (setx xxx t)) ;; const or variable?
>
> (let ((xxx nil))
>   (change-xxx))

It could be caught, if it was so defined by the language.

For example, in the case of Common Lisp, it is forbidden to rebind
lexically or dynamically a constant.

    The consequences are undefined when constant symbols are rebound
    as either lexical or dynamic variables. In other words, a
    reference to a symbol declared with defconstant always refers to
    its global value.



Again, in both languages, a good solution is to mark constants with
plus signs, so you're not tempted to rebind them.


-- 
__Pascal Bourguignon__


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

* Re: Working with constansts
       [not found]               ` <mailman.7056.1242122790.31690.help-gnu-emacs@gnu.org>
@ 2009-05-12 11:54                 ` Pascal J. Bourguignon
  2009-05-18 10:55                   ` Nikolaj Schumacher
       [not found]                 ` <7ceiuuczad.fsf@pbourguignon.informatimago.com>
  1 sibling, 1 reply; 28+ messages in thread
From: Pascal J. Bourguignon @ 2009-05-12 11:54 UTC (permalink / raw)
  To: help-gnu-emacs

Nikolaj Schumacher <me@nschum.de> writes:

> pjb@informatimago.com (Pascal J. Bourguignon) wrote:
>
>> Richard Riley <rileyrgdev@googlemail.com> writes:
>>
>>> Of course I understand if the answer is "history and that's the way it
>>> is" but I would sympathise with a new programmer to Lisp that is
>>> surprised he can modify a "const" especially if he came from a C/C++
>>> background where we all fully understand WHY consts are useful for the
>>> programmer but the compiler also enforced it.
>>
>> The important point is that a lisp system is being programmed at the
>> same time it is executed.  Therefore redefining a constant may be
>> taken into account, because it may be what the _programmer_ really
>> means.
>>
>> In C, you would have to recompile the program before a change to a
>> constant is taken into account, but it would be very possible to
>> modify a constant: nothing prevents you to edit the C sources,
>> recompile and relaunch.
>
> Certainly const in C doesn't mean the value is determined at compile
> time.  It just means: "This variable shouldn't be modified after its
> initialization."
>
> And in fact, you can cast constness away in C++, so it really has
> nothing to do with execution versus compile time.  It's just a helper
> for the developer to prevent side-effects.

However, the C or C++ compilers are allowed to consider that the value
of the constant won't change, so they may inline any number of copies
they want.  Changing the value stored in the const variable won't
archieve much.  The same may occur in Common Lisp.  

-*- mode: compilation; default-directory: "~/src/tests-c++/" -*-
Compilation started at Tue May 12 13:46:08

$ gcc -O3 -S -o constant.s constant.c ; cat constant.c ; echo ------------------- ; cat constant.s

const int c=42;

int f(int x){ return c+x; }

-------------------
	.file	"constant.c"
	.text
	.p2align 4,,15
.globl f
	.type	f, @function
f:
.LFB2:
	leal	42(%rdi), %eax                 -------- first copy of the constant
	ret
.LFE2:
	.size	f, .-f
.globl c
	.section	.rodata
	.align 4
	.type	c, @object
	.size	c, 4
c:
	.long	42                              --------- second copy of the constant
	.section	.eh_frame,"a",@progbits
.Lframe1:
	.long	.LECIE1-.LSCIE1
.LSCIE1:
	.long	0x0
	.byte	0x1
	.string	"zR"
	.uleb128 0x1
	.sleb128 -8
	.byte	0x10
	.uleb128 0x1
	.byte	0x3
	.byte	0xc
	.uleb128 0x7
	.uleb128 0x8
	.byte	0x90
	.uleb128 0x1
	.align 8
.LECIE1:
.LSFDE1:
	.long	.LEFDE1-.LASFDE1
.LASFDE1:
	.long	.LASFDE1-.Lframe1
	.long	.LFB2
	.long	.LFE2-.LFB2
	.uleb128 0x0
	.align 8
.LEFDE1:
	.ident	"GCC: (Gentoo 4.3.3-r1 p1.1, pie-10.1.5) 4.3.3"
	.section	.note.GNU-stack,"",@progbits

Compilation finished at Tue May 12 13:46:08



> There really is no pressing requirement for the current behavior, the
> run-time just doesn't verify it.  

Nothing would prevent emacs lisp to specify defconst in such a way the
byte compiler could do the same.  Only in the case of emacs it's more
practical to change the value of the constant, because it means that
you can modify your program without having to restart emacs, which is
a good thing in the case of an editor/IDE/OS.


> It does one thing, though:
>
> (setq xxx 'user)
> (defvar xxx 'library)
> xxx => 'user
>
> (setq xxx 'user)
> (defconst xxx 'library)
> xxx => 'library
>
> A tiny step towards enforcing the value.
>
>
> regards,
> Nikolaj Schumacher

-- 
__Pascal Bourguignon__


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

* Re: Working with constansts
       [not found]             ` <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>
  2009-05-12 11:43               ` Pascal J. Bourguignon
@ 2009-05-13  4:59               ` Barry Margolin
  2009-05-13 13:41                 ` Ralf Wachinger
  1 sibling, 1 reply; 28+ messages in thread
From: Barry Margolin @ 2009-05-13  4:59 UTC (permalink / raw)
  To: help-gnu-emacs

In article <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>,
 Nikolaj Schumacher <me@nschum.de> wrote:

> Richard Riley <rileyrgdev@googlemail.com> wrote:
> 
> >> Because this would incur overhead on every assignment, as it would have 
> >> to check whether the variable being assigned was declared as a constant.  
> >> Since this is so rarely the case, this overhead could be seen as mostly 
> >> wasted and unnecessary.
> >
> > I don't know enough about Lisp than I can only assume that in this case
> > it can not be detected at compile time IF you compile to byte/p code.
> 
> "Thanks" to dynamic scoping it cannot be caught at compile time.

It could at least generate a warning.

> (defconst xxx nil)
> 
> (defun change-xxx ()
>   (setx xxx t)) ;; const or variable?
> 
> (let ((xxx nil))
>   (change-xxx))

This should also warn about binding a constant.

-- 
Barry Margolin, barmar@alum.mit.edu
Arlington, MA
*** PLEASE post questions in newsgroups, not directly to me ***
*** PLEASE don't copy me on replies, I'll read them in the group ***


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

* Re: Working with constansts
  2009-05-13  4:59               ` Barry Margolin
@ 2009-05-13 13:41                 ` Ralf Wachinger
  2009-05-13 21:23                   ` Barry Margolin
  0 siblings, 1 reply; 28+ messages in thread
From: Ralf Wachinger @ 2009-05-13 13:41 UTC (permalink / raw)
  To: help-gnu-emacs

* Barry Margolin wrote:

> In article <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>,
>  Nikolaj Schumacher <me@nschum.de> wrote:
> 
>> Richard Riley <rileyrgdev@googlemail.com> wrote:
> 
>>> I don't know enough about Lisp than I can only assume that in this case
>>> it can not be detected at compile time IF you compile to byte/p code.
>> 
>> "Thanks" to dynamic scoping it cannot be caught at compile time.
> 
> It could at least generate a warning.
> 
>> (defconst xxx nil)
>> 
>> (defun change-xxx ()
>>   (setx xxx t)) ;; const or variable?
>> 
>> (let ((xxx nil))
>>   (change-xxx))
> 
> This should also warn about binding a constant.

This recalls the discussions on constants (general), getters and setters
(OOP) in Python to my mind. Functions as wrappers to enforce the
intentions of the programmers. There are no constants (and even no
declarations) in Python, there's only the convention to write intended
constants in capitals. 

For class and instance attributes there are no private, protected or
public declarations (you can even add attributes from outside later) in
Python, there's only a convention to start the intended non-public
attributes with an underline character.

"The pythonic way" informs the users about the intentions, it doesn't
restrict the users. I see that Python and Elisp have a pretty similar
concept on the whole, both are very dynamic and unrestricted.


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

* Re: Working with constansts
  2009-05-13 13:41                 ` Ralf Wachinger
@ 2009-05-13 21:23                   ` Barry Margolin
  0 siblings, 0 replies; 28+ messages in thread
From: Barry Margolin @ 2009-05-13 21:23 UTC (permalink / raw)
  To: help-gnu-emacs

In article <20090513.geh.3ab9xhlg.2@wachinger.fqdn.th-h.de>,
 Ralf Wachinger <rwnewsmampfer@geekmail.de> wrote:

> * Barry Margolin wrote:
> 
> > In article <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>,
> >  Nikolaj Schumacher <me@nschum.de> wrote:
> > 
> >> Richard Riley <rileyrgdev@googlemail.com> wrote:
> > 
> >>> I don't know enough about Lisp than I can only assume that in this case
> >>> it can not be detected at compile time IF you compile to byte/p code.
> >> 
> >> "Thanks" to dynamic scoping it cannot be caught at compile time.
> > 
> > It could at least generate a warning.
> > 
> >> (defconst xxx nil)
> >> 
> >> (defun change-xxx ()
> >>   (setx xxx t)) ;; const or variable?
> >> 
> >> (let ((xxx nil))
> >>   (change-xxx))
> > 
> > This should also warn about binding a constant.
> 
> This recalls the discussions on constants (general), getters and setters
> (OOP) in Python to my mind. Functions as wrappers to enforce the
> intentions of the programmers. There are no constants (and even no
> declarations) in Python, there's only the convention to write intended
> constants in capitals. 

We also have naming conventions in Lisp: *var* for global variables, 
+var+ for constants (although this convention postdates the Common Lisp 
specification, so none of the constants defined in the language follow 
it).

> 
> For class and instance attributes there are no private, protected or
> public declarations (you can even add attributes from outside later) in
> Python, there's only a convention to start the intended non-public
> attributes with an underline character.

CLOS is similar, there's no information hiding.  Packages are usually 
used to distinguish the public vs internal interfaces, but the CL 
package system doesn't prevent outsiders from accessing non-exported 
symbols.

> 
> "The pythonic way" informs the users about the intentions, it doesn't
> restrict the users. I see that Python and Elisp have a pretty similar
> concept on the whole, both are very dynamic and unrestricted.

The reason for Common Lisp's restrictions on constant is to give more 
flexibility to implementors, to allow for better optimization.  By 
prohibiting assignment to constants, the compiler can perform inline 
substitution.

This is less of an issue for interpreted languages, so they tend to be 
more permissive.

-- 
Barry Margolin, barmar@alum.mit.edu
Arlington, MA
*** PLEASE post questions in newsgroups, not directly to me ***
*** PLEASE don't copy me on replies, I'll read them in the group ***


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

* Re: Working with constansts
  2009-05-12 11:54                 ` Pascal J. Bourguignon
@ 2009-05-18 10:55                   ` Nikolaj Schumacher
  0 siblings, 0 replies; 28+ messages in thread
From: Nikolaj Schumacher @ 2009-05-18 10:55 UTC (permalink / raw)
  To: Pascal J. Bourguignon; +Cc: help-gnu-emacs

pjb@informatimago.com (Pascal J. Bourguignon) wrote:

>> And in fact, you can cast constness away in C++, so it really has
>> nothing to do with execution versus compile time.  It's just a helper
>> for the developer to prevent side-effects.
>
> However, the C or C++ compilers are allowed to consider that the value
> of the constant won't change, so they may inline any number of copies
> they want.

Yes, I was thinking of const references... And in lisp, consts would
actually be references (maybe with the exception of numbers)

(defconst x '(foo . bar)

We've talked about (setq x 'foo) being illegal, but that would not
prevent (setcar x 'bar).  And even if you prevent that, you can have:

(defvar y '(foo . bar)
(defconst x y)

Now the compiler cannot assume that y will not change, it's just a
reminder to the developer.

>> There really is no pressing requirement for the current behavior, the
>> run-time just doesn't verify it.  
>
> Nothing would prevent emacs lisp to specify defconst in such a way the
> byte compiler could do the same.  Only in the case of emacs it's more
> practical to change the value of the constant, because it means that
> you can modify your program without having to restart emacs, which is
> a good thing in the case of an editor/IDE/OS.

And nothing would prevent the byte-compiler (and eval-last-sexp) to have
special privileges for overriding consts in a live environment.  (You
don't have to format a disk to reclaim write-protected files, either.)

Certainly, inconsistencies might appear, unless every function inlining
the value is also re-evaluated.  But that's also the case with macros.



regards,
Nikolaj Schumacher




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

* Re: Working with constansts
       [not found]                   ` <mailman.7379.1242644154.31690.help-gnu-emacs@gnu.org>
@ 2009-05-18 12:20                     ` Pascal J. Bourguignon
  2009-05-18 19:19                       ` Nikolaj Schumacher
  0 siblings, 1 reply; 28+ messages in thread
From: Pascal J. Bourguignon @ 2009-05-18 12:20 UTC (permalink / raw)
  To: help-gnu-emacs

Nikolaj Schumacher <me@nschum.de> writes:

> pjb@informatimago.com (Pascal J. Bourguignon) wrote:
>
>>> And in fact, you can cast constness away in C++, so it really has
>>> nothing to do with execution versus compile time.  It's just a helper
>>> for the developer to prevent side-effects.
>>
>> However, the C or C++ compilers are allowed to consider that the value
>> of the constant won't change, so they may inline any number of copies
>> they want.
>
> Yes, I was thinking of const references... And in lisp, consts would
> actually be references (maybe with the exception of numbers)
>
> (defconst x '(foo . bar)
>
> We've talked about (setq x 'foo) being illegal, but that would not
> prevent (setcar x 'bar).  And even if you prevent that, you can have:
>
> (defvar y '(foo . bar)
> (defconst x y)
>
> Now the compiler cannot assume that y will not change, it's just a
> reminder to the developer.


Well, you shouldn't modify quoted literals either, since this is
modifying the program:

(defun f (x)
   (let ((y '(foo . bar)))
     (prog1 (car y)
        (setf (car y) x))))

(list (f 1) (f 2) (f 3) (symbol-function 'f)) 
--> (foo 1 2 (lambda (x) (let ((y (quote (3 . bar)))) (prog1 (car y) (setf (car y) x)))))



But what you say is correct, in the case of:

(defvar y (cons 'foo 'bar))
(defconst x y)


>>> There really is no pressing requirement for the current behavior, the
>>> run-time just doesn't verify it.  
>>
>> Nothing would prevent emacs lisp to specify defconst in such a way the
>> byte compiler could do the same.  Only in the case of emacs it's more
>> practical to change the value of the constant, because it means that
>> you can modify your program without having to restart emacs, which is
>> a good thing in the case of an editor/IDE/OS.
>
> And nothing would prevent the byte-compiler (and eval-last-sexp) to have
> special privileges for overriding consts in a live environment.  (You
> don't have to format a disk to reclaim write-protected files, either.)
>
> Certainly, inconsistencies might appear, unless every function inlining
> the value is also re-evaluated.  But that's also the case with macros.
>
>
>
> regards,
> Nikolaj Schumacher

-- 
__Pascal Bourguignon__


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

* Re: Working with constansts
  2009-05-18 12:20                     ` Pascal J. Bourguignon
@ 2009-05-18 19:19                       ` Nikolaj Schumacher
  0 siblings, 0 replies; 28+ messages in thread
From: Nikolaj Schumacher @ 2009-05-18 19:19 UTC (permalink / raw)
  To: Pascal J. Bourguignon; +Cc: help-gnu-emacs

pjb@informatimago.com (Pascal J. Bourguignon) wrote:

> Nikolaj Schumacher <me@nschum.de> writes:
>
>> (defvar y '(foo . bar)
>> (defconst x y)
>>
>> Now the compiler cannot assume that y will not change, it's just a
>> reminder to the developer.
>
> Well, you shouldn't modify quoted literals either, since this is
> modifying the program:

What program?  No form is stored in that case.


regards,
Nikolaj Schumacher




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

end of thread, other threads:[~2009-05-18 19:19 UTC | newest]

Thread overview: 28+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-05-10 15:25 Working with constansts Decebal
2009-05-10 16:19 ` Pascal J. Bourguignon
2009-05-10 16:20   ` Richard Riley
2009-05-10 16:33     ` Pascal J. Bourguignon
2009-05-12 10:34       ` Nikolaj Schumacher
2009-05-10 17:02     ` Drew Adams
2009-05-10 17:28       ` Richard Riley
2009-05-11  7:39         ` Tassilo Horn
     [not found]       ` <mailman.6953.1241976532.31690.help-gnu-emacs@gnu.org>
2009-05-10 18:17         ` Pascal J. Bourguignon
2009-05-11  1:36           ` Richard Riley
2009-05-11  6:29             ` Pascal J. Bourguignon
2009-05-12 10:06               ` Nikolaj Schumacher
     [not found]               ` <mailman.7056.1242122790.31690.help-gnu-emacs@gnu.org>
2009-05-12 11:54                 ` Pascal J. Bourguignon
2009-05-18 10:55                   ` Nikolaj Schumacher
     [not found]                 ` <7ceiuuczad.fsf@pbourguignon.informatimago.com>
     [not found]                   ` <mailman.7379.1242644154.31690.help-gnu-emacs@gnu.org>
2009-05-18 12:20                     ` Pascal J. Bourguignon
2009-05-18 19:19                       ` Nikolaj Schumacher
2009-05-10 18:59         ` Barry Margolin
2009-05-11  1:38           ` Richard Riley
2009-05-12  9:44             ` Nikolaj Schumacher
     [not found]             ` <mailman.7052.1242121473.31690.help-gnu-emacs@gnu.org>
2009-05-12 11:43               ` Pascal J. Bourguignon
2009-05-13  4:59               ` Barry Margolin
2009-05-13 13:41                 ` Ralf Wachinger
2009-05-13 21:23                   ` Barry Margolin
2009-05-11  9:58     ` Thien-Thi Nguyen
     [not found]     ` <mailman.6988.1242036217.31690.help-gnu-emacs@gnu.org>
2009-05-12  1:31       ` Barry Margolin
2009-05-11  8:27   ` Decebal
2009-05-12  9:46     ` Nikolaj Schumacher
2009-05-10 16:31 ` Drew Adams

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