all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* bug in field-string and field-string-no-properties
@ 2003-08-14 21:00 Greg Hill
  2003-08-14 21:21 ` John Paul Wallington
  0 siblings, 1 reply; 8+ messages in thread
From: Greg Hill @ 2003-08-14 21:00 UTC (permalink / raw)


There appears to be a bug in field-string and 
field-string-no-properties.  When (point) or the POS argument is at 
the first character of a field, the function returns an empty string. 
The following fragment of code, executed in the scratch buffer, 
illustrates the problem.

(progn
   (set-buffer (get-buffer-create "junk"))
   (erase-buffer)
   (insert "Test")
   (put-text-property (point-min) (point-max) 'field 1)
   (message "field-string at 1 = '%s'\nfield-string at 2 = '%s'"
   (field-string-no-properties 1) (field-string-no-properties 2)))


platform:  GNU Emacs 21.2.2 (sparc-sun-solaris2.7, X toolkit)

--Greg

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

* Re: bug in field-string and field-string-no-properties
  2003-08-14 21:00 Greg Hill
@ 2003-08-14 21:21 ` John Paul Wallington
  0 siblings, 0 replies; 8+ messages in thread
From: John Paul Wallington @ 2003-08-14 21:21 UTC (permalink / raw)
  Cc: bug-gnu-emacs

> There appears to be a bug in field-string and 
> field-string-no-properties.  When (point) or the POS argument is at 
> the first character of a field, the function returns an empty string. 
> The following fragment of code, executed in the scratch buffer, 
> illustrates the problem.
> 
> (progn
>    (set-buffer (get-buffer-create "junk"))
>    (erase-buffer)
>    (insert "Test")
>    (put-text-property (point-min) (point-max) 'field 1)
>    (message "field-string at 1 = '%s'\nfield-string at 2 = '%s'"
>    (field-string-no-properties 1) (field-string-no-properties 2)))

>From (elisp) Fields Info node:

"When the characters before and after POS are part of the same field,
there is no doubt which field contains POS: the one those characters
both belong to.  When POS is at a boundary between fields, which field
it belongs to depends on the stickiness of the `field' properties of
the two surrounding characters (see *note Sticky Properties::).  The field
whose property would be inherited by text inserted at POS is the field
that contains POS."

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

* [ghill@synergymicro.com: Re: Re: bug in field-string and field-string-no-properties]
@ 2003-08-27 22:12 Richard Stallman
  2003-08-28 21:32 ` Fwd: Re: Re: bug in field-string and field-string-no-properties Stefan Monnier
  0 siblings, 1 reply; 8+ messages in thread
From: Richard Stallman @ 2003-08-27 22:12 UTC (permalink / raw)
  Cc: emacs-devel

Would you please give me your thoughts on this issue?  What he says
seems logical; at the same time, I'm concerned that changing the spec
of field-string could easily break something that depends on the
current behavior.

(Everyone else is welcome to discuss it too, but I particularly
am looking for Stefan's and Miles' thoughts.)

------- Start of forwarded message -------
In-Reply-To: <3F3BA301.4522.6E53D5@localhost>
Date: Thu, 14 Aug 2003 18:00:38 -0700
To: John Paul Wallington <jpw@gnu.org>
From: Greg Hill <ghill@synergymicro.com>
Cc: bug-gnu-emacs@gnu.org
Subject: Re: Re: bug in field-string and field-string-no-properties
Sender: bug-gnu-emacs-bounces+rms=gnu.org@gnu.org

>  > There appears to be a bug in field-string and
>>  field-string-no-properties.  When (point) or the POS argument is at
>>  the first character of a field, the function returns an empty
>>  string. The following fragment of code, executed in the scratch
>>  buffer, illustrates the problem.
>>
>  > (progn
>>     (set-buffer (get-buffer-create "junk"))
>>     (erase-buffer)
>>     (insert "Test")
>>     (put-text-property (point-min) (point-max) 'field 1)
>>     (message "field-string at 1 = '%s'\nfield-string at 2 = '%s'"
>>     (field-string-no-properties 1) (field-string-no-properties 2)))
>
>>From (elisp) Fields Info node:
>
>"When the characters before and after POS are part of the same field,
>there is no doubt which field contains POS: the one those characters
>both belong to.  When POS is at a boundary between fields, which field
>it belongs to depends on the stickiness of the `field' properties of
>the two surrounding characters (see *note Sticky Properties::).  The
>field whose property would be inherited by text inserted at POS is the
>field that contains POS."

If stickiness is the issue, then the default rear-stickiness of the 
last character of a field should identify the field-string "to the 
left of" a point; but as the example below shows, it does not.  It 
seems to me that for a four-character field there ought to be at 
least four places at which field-string will return it.

As it stands, field-string returns a string only if the character to 
the left AND the character to the right of POS both have the same 
field property.  That means, of course, that for a field that is one 
character long, there is no way you can ever get field-string to 
return anything but an empty string.

(progn
    (set-buffer (get-buffer-create "junk"))
    (erase-buffer)
    (insert "Test")
    (put-text-property (point-min) (point-max) 'field 1)
    (message "field-string at 1 = '%s'\nfield-string at 2 = 
'%s'\nfield-string at (point-max) = '%s'"
	    (field-string-no-properties 1)
	    (field-string-no-properties 2)
	    (field-string-no-properties (point-max)) ) )

- --Greg


_______________________________________________
Bug-gnu-emacs mailing list
Bug-gnu-emacs@gnu.org
http://mail.gnu.org/mailman/listinfo/bug-gnu-emacs
------- End of forwarded message -------

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

* Re: Fwd: Re: Re: bug in field-string and field-string-no-properties
  2003-08-27 22:12 [ghill@synergymicro.com: Re: Re: bug in field-string and field-string-no-properties] Richard Stallman
@ 2003-08-28 21:32 ` Stefan Monnier
  2003-08-29  2:20   ` Greg Hill
  0 siblings, 1 reply; 8+ messages in thread
From: Stefan Monnier @ 2003-08-28 21:32 UTC (permalink / raw)
  Cc: auto-added, emacs-devel, monnier, miles

> Would you please give me your thoughts on this issue?  What he says
> seems logical; at the same time, I'm concerned that changing the spec
> of field-string could easily break something that depends on the
> current behavior.
> 
> (Everyone else is welcome to discuss it too, but I particularly
> am looking for Stefan's and Miles' thoughts.)

I remember replying, but I can't find the reply any more.
Here is a short summary: I think the current behavior is correct and as
for bugs, I don't know any right now (and since the code is used for the
minibuffer, it's unlikely that we'll see bugs in situations similar
to the minibuffer).

> ------- Start of forwarded message -------
> In-Reply-To: <3F3BA301.4522.6E53D5@localhost>
> Date: Thu, 14 Aug 2003 18:00:38 -0700
> To: John Paul Wallington <jpw@gnu.org>
> From: Greg Hill <ghill@synergymicro.com>
> Cc: bug-gnu-emacs@gnu.org
> Subject: Re: Re: bug in field-string and field-string-no-properties
> Sender: bug-gnu-emacs-bounces+rms=gnu.org@gnu.org
> 
> >  > There appears to be a bug in field-string and
> >>  field-string-no-properties.  When (point) or the POS argument is at
> >>  the first character of a field, the function returns an empty
> >>  string. The following fragment of code, executed in the scratch
> >>  buffer, illustrates the problem.
> >>
> >  > (progn
> >>     (set-buffer (get-buffer-create "junk"))
> >>     (erase-buffer)
> >>     (insert "Test")
> >>     (put-text-property (point-min) (point-max) 'field 1)
> >>     (message "field-string at 1 = '%s'\nfield-string at 2 = '%s'"
> >>     (field-string-no-properties 1) (field-string-no-properties 2)))
> >
> >>From (elisp) Fields Info node:
> >
> >"When the characters before and after POS are part of the same field,
> >there is no doubt which field contains POS: the one those characters
> >both belong to.  When POS is at a boundary between fields, which field
> >it belongs to depends on the stickiness of the `field' properties of
> >the two surrounding characters (see *note Sticky Properties::).  The
> >field whose property would be inherited by text inserted at POS is the
> >field that contains POS."
> 
> If stickiness is the issue, then the default rear-stickiness of the
> last character of a field should identify the field-string "to the
> left of" a point; but as the example below shows, it does not.  It

I don't see how the example shows that.

> seems to me that for a four-character field there ought to be at 
> least four places at which field-string will return it.

There are.  At positions 2, 3, 4, and 5.
For non-sticky, there'll only be 3 positions and for red and front sticky
properties, there will be 5 positions where field-string will return
the field.

> As it stands, field-string returns a string only if the character to
> the left AND the character to the right of POS both have the same
> field property.

Can you show a precise test case that shows that ?
It works correctly in my tests (and in actual use by `customize' it also
seems to work).


	Stefan

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

* Re: Fwd: Re: Re: bug in field-string and field-string-no-properties
  2003-08-28 21:32 ` Fwd: Re: Re: bug in field-string and field-string-no-properties Stefan Monnier
@ 2003-08-29  2:20   ` Greg Hill
  2003-08-29  2:36     ` Miles Bader
  0 siblings, 1 reply; 8+ messages in thread
From: Greg Hill @ 2003-08-29  2:20 UTC (permalink / raw)
  Cc: emacs-devel, monnier, miles

At 5:32 PM -0400 8/28/03, Stefan Monnier wrote:
<snip>
>
>  > As it stands, field-string returns a string only if the character to
>  > the left AND the character to the right of POS both have the same
>  > field property.
>
>Can you show a precise test case that shows that ?
>It works correctly in my tests (and in actual use by `customize' it also
>seems to work).

(progn
   (set-buffer (get-buffer-create "junk"))
   (erase-buffer)
   (insert "xXyY")
   (put-text-property 1 3 'field 'X)
   (put-text-property 3 5 'field 'Y)
   (message (concat "At 1, field-property = %s, field-string = '%s'\n"
		   " At 2, field-property = %s, field-string = '%s'\n"
		   " At 3, field-property = %s, field-string = '%s'\n"
		   " At 4, field-property = %s, field-string = '%s'\n"
		   " At 5, field-property = %s, field-string = '%s'\n")
	   (get-text-property 1 'field) (field-string-no-properties 1)
	   (get-text-property 2 'field) (field-string-no-properties 2)
	   (get-text-property 3 'field) (field-string-no-properties 3)
	   (get-text-property 4 'field) (field-string-no-properties 4)
	   (get-text-property 5 'field) (field-string-no-properties 5)))

produces:

"At 1, field-property = X, field-string = ''
  At 2, field-property = X, field-string = 'xX'
  At 3, field-property = Y, field-string = ''
  At 4, field-property = Y, field-string = 'yY'
  At 5, field-property = nil, field-string = ''
"

The kind of function I would find useful wouldn't depend on 
stickiness at all.  For a given buffer position, the value of the 
field property returned by get-text-property would determine the 
string returned by field-string when it is passed the same buffer 
position.  Thus, in the example above, since the characters at 
positions 3 and 4 both have the same value, 'Y, for their field 
property, field-string would return the same string, "yY", for both 
of those positions.  If this were the case, the `buffer-pos' in the 
event caused by mouse-clicking on the "y" at position 3 in the 
example above would always return "yY" as the field-string, not an 
empty string, and certainly not "xX" just because the "X" happened to 
be rear-sticky.

--Greg

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

* Re: bug in field-string and field-string-no-properties
  2003-08-29  2:20   ` Greg Hill
@ 2003-08-29  2:36     ` Miles Bader
  2003-08-29 18:53       ` Kevin Rodgers
  2003-08-29 21:55       ` Greg Hill
  0 siblings, 2 replies; 8+ messages in thread
From: Miles Bader @ 2003-08-29  2:36 UTC (permalink / raw)
  Cc: emacs-devel, Stefan Monnier, monnier, Richard Stallman

Greg Hill <ghill@synergymicro.com> writes:
> "At 1, field-property = X, field-string = ''
>   At 2, field-property = X, field-string = 'xX'
>   At 3, field-property = Y, field-string = ''
>   At 4, field-property = Y, field-string = 'yY'
>   At 5, field-property = nil, field-string = ''
> "

What version of emacs are you using?  My emacs (roughly CVS HEAD),
returns:

   "At 1, field-property = X, field-string = ''
    At 2, field-property = X, field-string = 'xX'
    At 3, field-property = Y, field-string = 'xX'
    At 4, field-property = Y, field-string = 'yY'
    At 5, field-property = nil, field-string = 'yY'
   "

which makes sense since the default for text-properties is rear-stickyness.

> The kind of function I would find useful wouldn't depend on stickiness
> at all.  For a given buffer position, the value of the field property
> returned by get-text-property would determine the string returned by
> field-string when it is passed the same buffer position.

There _is_ a reason why fields use stickiness for ambiguous locations:
it yields consistent result with what happens when a user inserts text,
and fields are fundamentally about inserting text.

Text insertion happens _between_ characters, and field operators
reflect that.

Perhaps mouse operations require some different operators, I don't know.

-Miles
-- 
"1971 pickup truck; will trade for guns"

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

* Re: bug in field-string and field-string-no-properties
  2003-08-29  2:36     ` Miles Bader
@ 2003-08-29 18:53       ` Kevin Rodgers
  2003-08-29 21:55       ` Greg Hill
  1 sibling, 0 replies; 8+ messages in thread
From: Kevin Rodgers @ 2003-08-29 18:53 UTC (permalink / raw)


Miles Bader wrote:

> Greg Hill <ghill@synergymicro.com> writes:
> 
>>"At 1, field-property = X, field-string = ''
>>  At 2, field-property = X, field-string = 'xX'
>>  At 3, field-property = Y, field-string = ''
>>  At 4, field-property = Y, field-string = 'yY'
>>  At 5, field-property = nil, field-string = ''
>>"
>>
> 
> What version of emacs are you using?

I get the same results as Greg on

GNU Emacs 21.3.1 (i386-pc-solaris2.7, X toolkit) of 2003-04-24 on briard

-- 
Kevin Rodgers

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

* Re: bug in field-string and field-string-no-properties
  2003-08-29  2:36     ` Miles Bader
  2003-08-29 18:53       ` Kevin Rodgers
@ 2003-08-29 21:55       ` Greg Hill
  1 sibling, 0 replies; 8+ messages in thread
From: Greg Hill @ 2003-08-29 21:55 UTC (permalink / raw)
  Cc: emacs-devel, Stefan Monnier, monnier, Richard Stallman

At 11:36 AM +0900 8/29/03, Miles Bader wrote:
>Greg Hill <ghill@synergymicro.com> writes:
>>  "At 1, field-property = X, field-string = ''
>>    At 2, field-property = X, field-string = 'xX'
>>    At 3, field-property = Y, field-string = ''
>>    At 4, field-property = Y, field-string = 'yY'
>>    At 5, field-property = nil, field-string = ''
>>  "
>
>What version of emacs are you using?


GNU Emacs 21.2.2 (sparc-sun-solaris2.7, X toolkit) of 2002-12-17


>   My emacs (roughly CVS HEAD),
>returns:
>
>    "At 1, field-property = X, field-string = ''
>     At 2, field-property = X, field-string = 'xX'
>     At 3, field-property = Y, field-string = 'xX'
>     At 4, field-property = Y, field-string = 'yY'
>     At 5, field-property = nil, field-string = 'yY'
>    "
>
>which makes sense since the default for text-properties is rear-stickyness.
>
>>  The kind of function I would find useful wouldn't depend on stickiness
>>  at all.  For a given buffer position, the value of the field property
>>  returned by get-text-property would determine the string returned by
>>  field-string when it is passed the same buffer position.
>
>There _is_ a reason why fields use stickiness for ambiguous locations:
>it yields consistent result with what happens when a user inserts text,
>and fields are fundamentally about inserting text.
>
>Text insertion happens _between_ characters, and field operators
>reflect that.
>
>Perhaps mouse operations require some different operators, I don't know.
>
>-Miles
>--
>"1971 pickup truck; will trade for guns"

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

end of thread, other threads:[~2003-08-29 21:55 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-08-27 22:12 [ghill@synergymicro.com: Re: Re: bug in field-string and field-string-no-properties] Richard Stallman
2003-08-28 21:32 ` Fwd: Re: Re: bug in field-string and field-string-no-properties Stefan Monnier
2003-08-29  2:20   ` Greg Hill
2003-08-29  2:36     ` Miles Bader
2003-08-29 18:53       ` Kevin Rodgers
2003-08-29 21:55       ` Greg Hill
  -- strict thread matches above, loose matches on Subject: below --
2003-08-14 21:00 Greg Hill
2003-08-14 21:21 ` John Paul Wallington

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.