9fans - fans of the OS Plan 9 from Bell Labs
 help / color / mirror / Atom feed
From: Paul Lalonde <plalonde@telus.net>
To: Fans of the OS Plan 9 from Bell Labs <9fans@cse.psu.edu>
Subject: Re: [9fans] const
Date: Wed,  7 Dec 2005 13:22:28 -0800	[thread overview]
Message-ID: <874BB1C1-E509-472F-8DBD-9EC0575E2F9B@telus.net> (raw)
In-Reply-To: <571511e7dddc323d94a6da81f35ba899@terzarima.net>


On 7-Dec-05, at 1:07 PM, Charles Forsyth wrote:
> if you followed the earlier links you'll see one of the classic  
> examples
> of it being fairly odd as an interface constraint:
>
> 	char* strchr(const char* x, int y)

I call this an interface bug: really, it should return a const char  
*, not a char *.  For the case where the input string was not const  
the user can obviously strip the constness from the return value.

It is a clear example of trying to make a piece of notation do two  
things.  One is to say that the function does not modify its  
paramter, which is of clear benefit to the optimizer when calling the  
function.  The second is to say that the data pointed to should not  
be changed, which is a semantic constraint for the programmer.
Ugly.

Paul




  parent reply	other threads:[~2005-12-07 21:22 UTC|newest]

Thread overview: 47+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-12-07 10:34 Steve Simon
2005-12-07 12:17 ` Russ Cox
2005-12-07 13:01   ` erik quanstrom
     [not found]   ` <000401c5fb32$64502e00$14aaa8c0@utelsystems.local>
2005-12-07 14:10     ` "Nils O. Selåsdal"
2005-12-07 15:05       ` Steve Simon
2005-12-07 15:30         ` Lucio De Re
2005-12-07 15:53           ` C H Forsyth
     [not found]         ` <1E68F99F-78D7-4321-BE56-7D0319212596@telus.net>
2005-12-07 16:11           ` "Nils O. Selåsdal"
2005-12-07 17:27             ` Paul Lalonde
2005-12-07 16:23 ` jmk
2005-12-07 17:28   ` Skip Tavakkolian
2005-12-07 18:51   ` Joel Salomon
2005-12-07 18:58     ` Charles Forsyth
2005-12-07 19:30       ` Joel Salomon
2005-12-07 19:36         ` Brantley Coile
2005-12-07 19:51         ` rog
2005-12-07 21:07         ` Charles Forsyth
2005-12-07 21:18           ` Bruce Ellis
2005-12-07 21:22           ` Paul Lalonde [this message]
2005-12-07 22:04             ` Rob Pike
2005-12-07 22:44           ` Micah Stetson
2005-12-07 22:44             ` Micah Stetson
2005-12-07 22:46               ` Brantley Coile
2005-12-07 20:33     ` Skip Tavakkolian
2005-12-08  7:39 ` geoff
2005-12-08  7:53   ` Lucio De Re
2005-12-08  7:54     ` geoff
2005-12-08 10:23       ` Bruce Ellis
2005-12-08 15:58   ` Brantley Coile
2005-12-09  1:44     ` geoff
2005-12-09  2:04       ` Russ Cox
2005-12-09  2:19         ` geoff
2005-12-09  9:54         ` Charles Forsyth
2005-12-09 16:25   ` David Leimbach
2005-12-09 16:59     ` Richard Bilson
2005-12-09 17:42       ` David Leimbach
2005-12-09 19:17         ` Richard Bilson
2005-12-09 17:01     ` Ronald G Minnich
2005-12-09 17:39       ` Russ Cox
2005-12-09 17:40       ` [9fans] PCICIA Modem TamTam
2005-12-09 18:59         ` Sascha Retzki
2005-12-12 15:07         ` Paweł Lasek
2005-12-26  9:00           ` Martin C. Atkins
2005-12-26 14:19             ` Paweł Lasek
2005-12-09 19:37       ` [9fans] Re: const Nikita Danilov
2005-12-09 20:30         ` Russ Cox
2005-12-09 20:37         ` Ronald G Minnich

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=874BB1C1-E509-472F-8DBD-9EC0575E2F9B@telus.net \
    --to=plalonde@telus.net \
    --cc=9fans@cse.psu.edu \
    /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.
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 NNTP newsgroup(s).