So we fork the current process, and then wait for our child process to finish? But where is our child process continuing his work? After the fork, we will go into the while-loop and and just skip some arguments and then return with ccode? Where was ccode changed? What is ccode?
Could you please explain me this the given code snippet? And elaborate on ccode?
As described in the man-page (if page from Section 1 of the unix-6th manual), if we put the command in brackets "if expr { command }", we can obtain his exit code.
If you look closely, I think you'll find that that is "if { command }" (with no expr); the exit status of command, in this case, is the expression.
ongoto already explained most of what is going on in the code above. From your comments above, I get the feeling that you don't understand how fork() works. If we look at the code:
Quote:
So we fork the current process, and then wait for our child process to finish?
What you have to understand is that after a successful call to fork(), it essentially returns twice; once in the parent process and once in the child process. In the parent process (the one that called fork()), the return code is never zero; if it is positive, it is the process ID of the newly created child process, and if it is negative, it indicates that the fork was unsuccessful and errno will indicate what error occurred (in this case there is no child process).
In the child process, fork() always returns zero.
Quote:
But where is our child process continuing his work?
So the code shown in green above, is only executed in the child process and the code shown in red is only executed in the parent process. Presumably, the function doex() in the child will parse the expression between the { and }, evaluate it, and then branch to the code at the label err which should terminate the child process with an exit code indicating whether the expression evaluated to true or false.
Quote:
After the fork, we will go into the while-loop and and just skip some arguments and then return with ccode? Where was ccode changed? What is ccode?
The wait(&ccode) in the parent waits for the child to exit and saves the exit status from the child in the variable ccode. Then the while loop in the parent skips over the expression that was evaluated by the child and returns true or false depending on the exit status of the child.
Note also that exit code 0 conventionally indicates success and a non-zero exit code indicates a failure. So, the command:
produces exit status zero if file is readable and produces a non-zero exit status if file can't be found or is not readable. As ongoto explained, the ternary operator converts the exit code convention (0 for success, non-zero for failure) into the C convention (1 for true, 0 for false).
This User Gave Thanks to Don Cragun For This Post:
I meant no offense.
I'm just going along with what you said. The questions you raised supports the fact that it doesn't make any sense, right?
if (exp()) is asking if the function exists; it's not calling that function.
...
The more I think about it, the less sure I am about that. As K&R C treats pretty much all functions as variable-argument, how could the compiler know what you meant? There's no way for a compiler to know if you're doing an existence check which would simply evaluate to the address of the function, or call the function with zero arguments.
I think there's a good chance that code that you identified actually does make the call to exp(), with unknown data on the stack. I think to just check if the function exists, the code would be if ( exp ).
Either way, anyone who writes code like that without comments on WHAT is being done is being incompetent, in my opinion.
When you go out into the esoteric edges of a programming language like that, even you are likely to not remember exactly what you did later on. And everyone else who didn't write the code is almost certainly going to be stumped for a good bit. Production or library code is not the place to compete in obscure coding ego wars.
And I freely admit that calling a vararg function with zero arguments makes no sense - with undefined junk on the stack, there's no way to know what would happen. That's another reason the code should be commented. To figure out what exactly is going on requires breaking out the C standard and maybe even hardware-specific behavior because "putting variables on the stack" is highly hardware-specific.
Thanks again ongoto, that helped me.
And thank you Don Cragun, for this detailed answer, I really appreciate it
@achenle
Notice that the parameter s in exp(s), isn't used at all in the function. So there should not be a problem calling exp(). So was it just a "mistake" by the programmer?
My last question now would be, how could I print the exit status of a command in unix v6?
I know nowadays you can do it with $?. But how did they do it at that time?
I think there's a good chance that code that you identified actually does make the call to exp(), with unknown data on the stack. I think to just check if the function exists, the code would be if ( exp ) .
That is possible. I can't remember all the type checking details used in those days either. One way Bash (nowadays) distinguises between a variable named 'func' and a function named 'func()' is the parentheses. But that may not have been true 20 years ago in the C language.
Thanks again ongoto, that helped me.
And thank you Don Cragun, for this detailed answer, I really appreciate it
@achenle
Notice that the parameter s in exp(s), isn't used at all in the function. So there should not be a problem calling exp(). So was it just a "mistake" by the programmer?
Without any comments from the programmer stating the intent of the code, it's impossible to tell.
Quote:
My last question now would be, how could I print the exit status of a command in unix v6?
I know nowadays you can do it with $?. But how did they do it at that time?
Depending on your command shell, it's usually something like this:
"$?" is usually the value returned from the last command run in a shell. csh is probably different, but I don't remember exactly.
Without any comments from the programmer stating the intent of the code, it's impossible to tell.
Depending on your command shell, it's usually something like this:
"$?" is usually the value returned from the last command run in a shell. csh is probably different, but I don't remember exactly.
One thing Bourne based shells and csh based shells share is that $? is the exit code of the previous command. But, we're talking about a UNIX Version 6 shell here; not a modern shell. I never used V6 much (although I worked on developing PWB UNIX and MERT both of which were derived from V6). I used the Mashey shell for a while and early versions of the Bourne shell (both of which were developed as replacements for the V6 shell). (As you can probably guess from current shells, the Mashey shell lost out to the Bourne shell; but some Mashey shell features were adopted by the Bourne shell.)
The V6 shell was VERY simple. (You can check out V6 utility man pages here.) Although there is no mention of shell variables or special parameters (e.g., $#, $?, and $!) on the V6 sh(1) man page and it is clear from the description of command execution that there was no $PATH variable, I think the special parameters listed above were provided with their current meanings. Positional parameters aren't even mentioned on the sh(1) man page, but $1 is mentioned on the goto(1) and shift(1) man pages. There were no loops (for, while, or until), but the the goto command could be used with the if command to produce loops. The only file descriptors you could redirect were standard input and standard output. (The BUGS section of the man page says it is a bug that diagnostic messages couldn't be redirected.) The Synopsis for the if command was:
Note that there is no then, else, or fi here. And, as has been noted in this thread, if was a standalone utility; not a shell built-in. If I remember correctly, the only built-ins in V6 sh were chdir (there was no cd then), login, newgrp, shift, and probably exit.
These 2 Users Gave Thanks to Don Cragun For This Post:
Hello,
I would like to know how we can highlight/select a section of a file in vi and delete that section if we don't want to use the dd command to delete one line at at time. There is one where we don't want to delete the whole line , but up to a certain word. (2 Replies)
1) The lpr and sort utilities accept input either from a file named on the command line or from standard input.
a)Name two other utilities that function in a similar manner.
b)Name a utility that accepts its input only from standard input.
2) Explain the following error message. What... (10 Replies)
1.) I am to write scripts that will be phasetest folder in the home directory.
2.) The folder should have a set-up,phase and display files
I have written a small script which i used to check for the existing users and their password.
What I need help with:
I have a set of questions in a... (19 Replies)
hey all, I have question when am writing simple shell...
in the child am calling execvp, i want the parent to know when execvp returns - 1. how can i let the parent know the result of execvp
thanks in advance (9 Replies)
Hi everyone im new to this forums, i just wanted to get started by asking a few question(Im a Unix newbie)
1. How do i sort a file called "dirr" in a ascending order on the 3rd column
2. what does alias on=who do
Thanks in advance!!! (1 Reply)
Hello Everbody
I hope you can give me a hand, I have some questions
The first one itīs about some message that I donīt know what means, I was looking about it. but nothing. This is the message
rsh: connection from bad port
bsd-gw: Error reading from connection: Bad file number
And my... (4 Replies)
Hi!
Im new to all this but the computer club im in has unix i think.
now my questions.
1.is it NTFS i need to partion the harddrive with to be able to use unix?
2.Unix and Linux whats the diffrense?yes im a noob got no idea been using crap windows for ages and hate it.
3.I got a win98... (2 Replies)