Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Call a function without argument, although it needs one [K&R-C]

Tags:

c

It's K&R-C and here is the code: http://v6shell.org/history/if.c

Look at the main-Method. There is this line "if(exp())".

But the function exp is declared as: exp(s). So it needs an argument.

Why does this work? And why would you do this?

like image 946
Joey Avatar asked Jan 01 '15 18:01

Joey


2 Answers

Ultimately, it is a bug in the Unix V6 shell support command, if.

The code for the function is:

exp(s) {
    int p1; 

    p1 = e1();
    if (eq(nxtarg(), "-o")) return(p1 | exp());
    ap--;
    return(p1);
}

The function parameter s, implicitly of type int (as is the function iteself), is actually unused in the function, so the bug is the presence of s, not the absence of an argument in the calls to exp(). All the calls with zero actual arguments are correct.

like image 112
Jonathan Leffler Avatar answered Sep 28 '22 08:09

Jonathan Leffler


If you look at the definition:

exp(s) {
    int p1;

    p1 = e1();

    if (eq(nxtarg(), "-o")) return(p1 | exp());
        ap--;

    return(p1);
}
  1. s is not used
  2. C doesn't require compile time type checking. It doesn't even require function parameters to be checked. Everything is a/series of bytes

Why does C not do any of those checks? From what I hear it's 'cause during first few years of C, computers were fairly weak. Doing those checks would require multiple passes to scan the source code, which basically increases compile time by a magnitude of n passes. So it just does a single pass, and takes every name as is, which is why function overloading is not supported

So if the definitions did make use of s in some way, you would most likely get some horrible runtime error with wonderful outputs to the console

like image 40
Alex Avatar answered Sep 28 '22 08:09

Alex