Why is C syntax so uneasy on the eye?
In its day, was it _really_ designed by snobby programmers to scare away
potential "n00bs"? If so, and after 50+ years of programming research,
why are programming languages still being designed with C's syntax?
These questions drive me insane. Every waking minute...
Nov 14 '05
177 7077
In article <ca***********@ sunnews.cern.ch > Da*****@cern.ch (Dan Pop) writes: In <Hz********@cwi .nl> "Dik T. Winter" <Di********@cwi .nl> writes:
.... It certainly is, when you expect *consistent* behaviour from vi on all platforms. The *last* thing I want to do when using vi is remembering on which platform I am and what is the right solution for my problem.
Wrong. You expect consistent behaviour from vi and vim, two completely different programs. That vim is called vi on some platforms is irrelevant.
I don't expect it, I'm doing my best to configure vi in such a way that it becomes consistent across platforms. I couldn't care less about the real name of the program I get when I invoke vi (at some time in the past, elvis and later nvi were the "vi" of the Linux distributions I was using).
In that case you should coplain that something that is not 'vi' is called
'vi' on some platform. Not complain that the real 'vi' does not conform
to the behaviour of what is called 'vi' on some platform.
I once used a program called 'ed' that in the case of an error did not
just print a question mark, but printed a long line explaining the error.
But I did *not* complain that there was no portable way to avoid that
behaviour... (The worst thing was that it was coming through a 1200 baud
link to Argonne in Chicago.) It is already bad enough that Solaris comes with an ancient, BSD-style vi that doesn't recognise the cursor keys in input mode...
Why, exactly, is this bad? And to be sure, I know of only one vi, the old BSD-style one.
That's due to your ignorance. There are also SystemV vi, POSIX vi, SUSx vi.
Probably. The first System V box I met in, say, 1985. By that time I had
already used BSD for some 6 years. The BSD subset I was comfortable with,
so when I first saw a System V vi, I did not feel the urge to find what it
could do more than BSD vi.
From the Solaris man page:
The standard Solaris version of vi will be replaced by the POSIX.2-conforming version (see standards(5)) in the future.
Yup, and if you had looked further you would have known that
/usr/xpg4/bin/vi is that POSIX.2-conforming version (I think).
This portion of the man page only says that /usr/bin/vi will be
replaced by /usr/xpg4/bin/vi. Others are clones under different names.
OK, what are the "real" names of "the standard Solaris version of vi", SystemV vi, POSIX vi and SUSx vi?
Those are not clones. But 'vim' very definitely *is* a clone, and
originally not very conforming to 'vi' behaviour either. This is similar to complaining that cc under Solaris does not do exactly the same as cc under Linux.
It is similar to complaining that a system supposend to follow a standard doesn't follow it completely. See the above quote from the vi man page on Solaris.
I do not know. Is "set expandtabs" in Posix.2 vi? What has Posix.2 to
say about shifting lines? So I do not know in what way 'vi' does not
follow standards. The 'vi' in /usr/xpg4/bin on Solaris (which is
ostensibly Posix.2 complliant) acts the same way.
That Bill Joy decided that a shift would mean recalculation of the total
indent is perhaps unfortunate, but understandable for that time (1978).
Moreover, at that time adding four spaces at the end of white space
already containing four spaces and not replacing things by a HT would
indeed mean a waste of resources. (Note that it adds nothing to an
empty line either...) On the other hand, which way you do it in a
number of cases you have to replace white-space characters in the
original by other white-space characters anyway.
--
dik t. winter, cwi, kruislaan 413, 1098 sj amsterdam, nederland, +31205924131
home: bovenover 215, 1025 jn amsterdam, nederland; http://www.cwi.nl/~dik/
In article <Hz********@cwi .nl>, Dik T. Winter <Di********@cwi .nl> wrote: That Bill Joy decided that a shift would mean recalculation of the total indent is perhaps unfortunate, but understandable for that time (1978).
26 years, and we're still waiting for vii.
-- Richard
Richard Bos <rl*@hoekstra-uitgeverij.nl> wrote: Dr Chaos <mb************ ****@NOSPAMyaho o.com> wrote:
On Wed, 26 May 2004 22:02:42 +0100, C# Learner <cs****@learner .here> wrote: > Why is C syntax so uneasy on the eye? > > In its day, was it _really_ designed by snobby programmers to scare away > potential "n00bs"? No, but the programmers who designed it didn't care about "n00bs"; their target audience was people who worked at Bell Labs. They were all very very smart.
Erm...
> If so, and after 50+ years of programming research, > why are programming languages still being designed with C's syntax?
Profound anti-intellectualism among practitioners, and cargo-cult imitation.
...don't you think these two statements are contradictory?
No.
The question is why are OTHER languages still designed and promoted
with C's syntax?
If it had been a Bell Labs research project to make ergonomic language
syntax suitable for broad use they would have done actual empirical research
with subjects who were not only other Bell Labs researchers.
In some small ways actual empirical testing have been done a few
times, but the results are generally ignored by commercial firms.
That's what I mean by "profound anti-intellectualism ", and the
"cargo-cult" imitation is the Microsoft (and Sun) manager arguing that
"it has to look like C to be successful", because C was successful.
In particular, the Fortran 90/Ada syntax for 'if then else' was preferred
over C or Pascal.
if something then
x1
x2
else
y1
y2
endif Richard
In <sl************ *************** ****@lyapunov.u csd.edu> Dr Chaos <mb************ ****@NOSPAMyaho o.com> writes: The question is why are OTHER languages still designed and promoted with C's syntax?
And the answer is obvious: because C syntax proved to be far more popular
than the syntax of any other HLL.
If it had been a Bell Labs research project to make ergonomic language syntax suitable for broad use they would have done actual empirical research with subjects who were not only other Bell Labs researchers.
The point is that C was designed with a concrete application in mind,
by the same programmers who used it to implement that application.
And its design was influenced by another language, designed for the same
purpose, by the same people, but for a different class of computers.
So, the language designers were not at their first attempt and had
excellent user feedback ;-) I doubt that an "ergonomica l" language
designed by a committee, based on world-wide empirical research, would
have been more popular among programmers.
Dan
--
Dan Pop
DESY Zeuthen, RZ group
Email: Da*****@ifh.de
On 23 Jun 2004 13:16:30 GMT, Dan Pop <Da*****@cern.c h> wrote: In <sl************ *************** ****@lyapunov.u csd.edu> Dr Chaos <mb************ ****@NOSPAMyaho o.com> writes:
The question is why are OTHER languages still designed and promoted with C's syntax? And the answer is obvious: because C syntax proved to be far more popular than the syntax of any other HLL.
but why?
is ther eanything good about the syntax other than that it was popular? If it had been a Bell Labs research project to make ergonomic language syntax suitable for broad use they would have done actual empirical research with subjects who were not only other Bell Labs researchers.
The point is that C was designed with a concrete application in mind, by the same programmers who used it to implement that application. And its design was influenced by another language, designed for the same purpose, by the same people, but for a different class of computers.
So, the language designers were not at their first attempt and had excellent user feedback ;-) I doubt that an "ergonomica l" language designed by a committee, based on world-wide empirical research, would have been more popular among programmers.
I think the popularity is because of the things which come attached
to the language, namely access to operating system features.
If the language syntax had been better cognitively, people would be
making fewer mistakes with the popular language. Dan -- Dan Pop DESY Zeuthen, RZ group Email: Da*****@ifh.de
"Dr Chaos" <mb************ ****@NOSPAMyaho o.com> wrote in message
news:sl******** *************** ********@lyapun ov.ucsd.edu... If the language syntax had been better cognitively, people would be making fewer mistakes with the popular language.
;-) good one!
In <sl************ *************** ****@lyapunov.u csd.edu> Dr Chaos <mb************ ****@NOSPAMyaho o.com> writes: On 23 Jun 2004 13:16:30 GMT, Dan Pop <Da*****@cern.c h> wrote: In <sl************ *************** ****@lyapunov.u csd.edu> Dr Chaos <mb************ ****@NOSPAMyaho o.com> writes:
The question is why are OTHER languages still designed and promoted with C's syntax? And the answer is obvious: because C syntax proved to be far more popular than the syntax of any other HLL.
but why?
is ther eanything good about the syntax other than that it was popular?
If it was bad, why did it become popular in the first place? If it had been a Bell Labs research project to make ergonomic language syntax suitable for broad use they would have done actual empirical research with subjects who were not only other Bell Labs researchers.
The point is that C was designed with a concrete application in mind, by the same programmers who used it to implement that application. And its design was influenced by another language, designed for the same purpose, by the same people, but for a different class of computers.
So, the language designers were not at their first attempt and had excellent user feedback ;-) I doubt that an "ergonomica l" language designed by a committee, based on world-wide empirical research, would have been more popular among programmers.
I think the popularity is because of the things which come attached to the language, namely access to operating system features.
Plenty of other languages predating C provided access to operating
system primitives. The need to access them without resorting to
assembly programming became clear far before Ken Thompson decided to
design and implement an OS for that unused PDP-7 sitting in a corner.
Even the idea of writing an OS in a HLL predates both Unix and C.
If the language syntax had been better cognitively, people would be making fewer mistakes with the popular language.
The syntax-related mistakes are relatively few, once people learn the
language, and the compiler must diagnose all of them. The real problem
is caused by the semantic mistakes and they have nothing to do with the
language syntax.
Dan
--
Dan Pop
DESY Zeuthen, RZ group
Email: Da*****@ifh.de
Dr Chaos <mb************ ****@NOSPAMyaho o.com> wrote: If the language syntax had been better cognitively, people would be making fewer mistakes with the popular language.
I find the language syntax good cognitively (with a few rare exceptions,
such as pointer to array of functions returning pointer to array of
function pointers, etc.)
If you don't, then maybe you are influenced by other languages with
similar syntax and have trouble keeping them separate in your head?
The only significant language I learned before C was line-number BASIC.
C's syntax is far superior for anything but the most basic (no pun
intended) expressions. This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics |
by: mike420 |
last post by:
I think everyone who used Python will agree that its syntax is
the best thing going for it. It is very readable and easy
for everyone to learn. But, Python does not a have very good
macro capabilities, unfortunately. I'd like to know if it may
be possible to add a powerful macro system to Python, while
keeping its amazing syntax, and if it could be possible to
add Pythonistic syntax to Lisp or Scheme, while keeping all
of the...
|
by: Tuang |
last post by:
I'm checking out Python as a candidate for replacing Perl as my "Swiss
Army knife" tool. The longer I can remember the syntax for performing
a task, the more likely I am to use it on the spot if the need arises.
If I have to go off and look it up, as I increasingly have to do with
Perl's ever hairier syntax, I'm more likely to just skip it, making me
even less likely to remember the syntax the next time.
So I hear that Python is easier...
|
by: Sandy Norton |
last post by:
If we are going to be stuck with @decorators for 2.4, then how about
using blocks and indentation to elminate repetition and increase
readability:
Example 1
---------
class Klass:
def __init__(self, name):
|
by: George Sakkis |
last post by:
I'm sure there must have been a past thread about this topic but I don't know how to find it: How
about extending the "for <X> in" syntax so that X can include default arguments ? This would be very
useful for list/generator comprehensions, for example being able to write something like:
instead of the less elegant explicit loop version that has to check for the length of each sequence.
What do you think ?
George
|
by: Carter Smith |
last post by:
http://www.icarusindie.com/Literature/ebooks/
Rather than advocating wasting money on expensive books for beginners,
here's my collection
of ebooks that have been made freely available on-line by their authors.
There are lots of them out there but this selection cuts out the junk.
If you know of any other good books that are freely available please post a
link to them here and I'll consider adding them to the site.
| |
by: Nicolas Fleury |
last post by:
Hi everyone, I would to know what do you think of this PEP. Any comment
welcomed (even about English mistakes).
PEP: XXX
Title: Specialization Syntax
Version: $Revision: 1.10 $
Last-Modified: $Date: 2003/09/22 04:51:49 $
Author: Nicolas Fleury <nidoizo at gmail.com>
Status: Draft
Type: Standards Track
|
by: Jeremy Yallop |
last post by:
Looking over some code I came across a line like this
if isalnum((unsigned char)c) {
which was accepted by the compiler without complaint. Should the
compiler have issued a diagnostic in this case? (I think it's not
required to, but I'd like confirmation).
Jeremy.
|
by: Bob hotmail.com> |
last post by:
Everyone
I have been spending weeks looking on the web for a good tutorial on how to use regular expressions and other methods to satisfy my craving for learning how to do FAST c-style syntax highlighting in C# but I have yet to find anything useful
I know there are people at MS that know this stuff like the front of their hand and I know there are many people out on the web that are proficient in doing this as well but it seems nobody...
|
by: Manuel |
last post by:
I'm trying to compile glut 3.7.6 (dowbloaded from official site)using
devc++.
So I've imported the glut32.dsp into devc++, included manually some
headers, and start to compile.
It return a very strange error. In your experience, where I should
looking to find the real error? Surely the sintax of glut is correct...
gcc.exe -c glut_bitmap.c -o glut_bitmap.o -I"C:/Dev-Cpp/include"
-I"../../include" -D__GNUWIN32__ -W -DWIN32 -DNDEBUG...
|
by: marktang |
last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However, people are often confused as to whether an ONU can Work As a Router. In this blog post, we’ll explore What is ONU, What Is Router, ONU & Router’s main usage, and What is the difference between ONU and Router. Let’s take a closer look !
Part I. Meaning of...
|
by: Hystou |
last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can effortlessly switch the default language on Windows 10 without reinstalling. I'll walk you through it.
First, let's disable language synchronization. With a Microsoft account, language settings sync across devices. To prevent any complications,...
| |
by: jinu1996 |
last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven tapestry of website design and digital marketing. It's not merely about having a website; it's about crafting an immersive digital experience that captivates audiences and drives business growth.
The Art of Business Website Design
Your website is...
|
by: tracyyun |
last post by:
Dear forum friends,
With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM).
In this session, we are pleased to welcome a new presenter, Adolph Dupré who will be discussing some powerful techniques for using class modules.
He will explain when you may want to use classes instead of User Defined Types (UDT). For example, to manage the data in unbound forms.
Adolph will...
|
by: conductexam |
last post by:
I have .net C# application in which I am extracting data from word file and save it in database particularly. To store word all data as it is I am converting the whole word file firstly in HTML and then checking html paragraph one by one.
At the time of converting from word file to html my equations which are in the word document file was convert into image.
Globals.ThisAddIn.Application.ActiveDocument.Select();...
|
by: adsilva |
last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?
|
by: muto222 |
last post by:
How can i add a mobile payment intergratation into php mysql website.
| |
by: bsmnconsultancy |
last post by:
In today's digital era, a well-designed website is crucial for businesses looking to succeed. Whether you're a small business owner or a large corporation in Toronto, having a strong online presence can significantly impact your brand's success. BSMN Consultancy, a leader in Website Development in Toronto offers valuable insights into creating effective websites that not only look great but also perform exceptionally well. In this comprehensive...
| |