From ... Path: archiver1.google.com!news1.google.com!newsfeed.stanford.edu!news-spur1.maxwell.syr.edu!news.maxwell.syr.edu!newsfeed.icl.net!newsfeed.fjserv.net!feed.news.nacamar.de!uio.no!Norway.EU.net!not-for-mail From: Erik Naggum Newsgroups: comp.lang.lisp Subject: Re: two questions about strings Date: 28 Jul 2002 18:37:53 +0000 Organization: Naggum Software, Oslo, Norway Lines: 78 Message-ID: <3236870273259433@naggum.net> References: <87wurgq241.fsf@darkstar.cartan> <87sn24q1y4.fsf@darkstar.cartan> <1eaf81aa.0207271939.6f6a048f@posting.google.com> <87y9bwdk6y.fsf@darkstar.cartan> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii X-Trace: oslo-nntp.eunet.no 1027881474 26232 193.71.199.50 (28 Jul 2002 18:37:54 GMT) X-Complaints-To: abuse@KPNQwest.no NNTP-Posting-Date: 28 Jul 2002 18:37:54 GMT Mail-Copies-To: never User-Agent: Gnus/5.09 (Gnus v5.9.0) Emacs/21.2 Xref: archiver1.google.com comp.lang.lisp:36929 * Nils Goesche | (defun isupper (char) | (char<= #\A char #\Z)) Despite all the good intentions and efforts to help this lost newbie, I think it is a mistake to try to help people who ask such questions. (This reply is not directed specifically towards Nils.) Defining your own because the standard function does not have the same name as in C is wrong. We already have upper-case-p, lower-case-p, alpha-char-p, etc, in Common Lisp. Reinventing wheels to look more like C will do nobody any good. Even asking for strlen and isupper is extremely counterproductive. People who ask for help in Common Lisp but refuse to relinquish their past language remind that I want to learn French, but only to hear it and read it. The utter helplessness of most French-speakers' attempt to produce English is so grating on my ears that I not only would like to be relieved of listening to it, speaking their language to them would probably be just as atrocious (almost like pronouncing "fromage" like "fromidge"). The original poster has no problem with strings, he has a problem with his willingness to learn Common Lisp. Much could be said about this affliction of the mind that causes people to assume that what they do not understand does not matter, that they have reached such a level of omniscience that they no longer need to observe and listen and learn. Having learned enough, some people evidently stop learning altogether. What they learned first is the standard for everything that comes later. That the probably only _truly_ random element in anyone's life is the order in which they experience things, seems not even to be underststandable -- they somehow believe that the order they run into them is universalizable and important, that first impressions really tell you everything you need to know about something. I have seen people who have the mental capacity only for the transition from "have not experienced" to "have experienced", and who are unable to make a distinction between their observations and their conclusions, such that they are unable to change their conclusions about what they observed. They walk around like they had CD-Rs for brains. What is the length of a string? C's string representation has no room for an allocated length vs an active length. C's string representation has no concept of substrings. C's strings cannot contain all possible characters. C's strlen is actually (position 0 :key #'char-code) and is O(n). Forget "strlen". For our immediate purposes, there is no "strlen". "strlen" does not _exist_. Common Lisp has vectors with fill-points, and strings are vectors which are sequences and arrays. Numerous functions that in other languages only work on strings, work on sequences in Commo Lisp. Functions like search, match, find, position, etc, are much more general than string functions in other languages. A string with a fill-pointer has a total and an active length. Most sequence functions accept bounding indices, start and end indices that make it possible to use substrings without modifying the target strings. Common Lisp even has displaced arrays if you really need a substring without copying the string contents. Common Lisp has string-streams to read from and write to strings in memory. Common Lisp has real charcters, not just small integers. Common Lisp's characters are not bytes, so when Unicode came along, there was no need to make extensive library and language changes. Common Lisp supports base and extended characters and hence base-string in addition to the general string. Common Lisp is a big-city language. Spit out the hayseed, pronounce "shit" with one syllable and "shotgun" with two. You're not in Kansas, anymore. C is the language of the poor farmer village where the allocation of every seed and livestock matters, where taxes are low and public service non-existent. Appreciating the value of a large language is evidently hard for many people, just like many people find themselves miserable in the big city and go to great lengths to create a small village for themselves in the city where everything is like it used to be where they came from. Common Lisp can accomodate people who want to program in any old language and re-create what they are used to, but if they want to get the most ouf ot it, the only way to do it is to adapt to the language and accept that somebody else may be better than you are at designing languages. -- Erik Naggum, Oslo, Norway ***** One manslaughter is another man's laughter. Act from reason, and failure makes you rethink and study harder. Act from faith, and failure makes you blame someone and push harder.