The key is in this:
previous implicit declaration of ‘point_forward’ was here
On line 96 you have:
point_forward(m); // where m is a mem_ptr;
Since the compiler hasn't yet seen a function declaration for point_forward(m)
, it "implicitly defines" (ie, assumes) a function that returns an int:
int point_forward(mem_ptr m);
This conflicts with the definition later:
void point_forward (mem_ptr m) {
To fix this, you can either:
Put an explicit declaration somewhere before line 96: void point_forward(mem_ptr m);
This will tell the compiler how to treat point_forward()
when it sees it on line 96, even though it hasn't yet seen the function implementation.
Or, define the whole function above line 96 (move the function definition from line 134 onwards to above line 96).
Here is a little bit more about declaring functions.
Generally, for style, I would either:
If you don't want to use point_forward()
in any other C files, define it in full:
static void point_forward(mem_ptr m) { ..function body goes here.. }
at the top of the source file.
If you want to use point_forward()
in other C files, put a forward declaration:
void point_forward(mem_ptr m);
in a header file for other files to include.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…