User Name Password Register
DaniWeb IT Discussion Community
All
What is DaniWeb IT Discussion Community?
You're currently browsing the C section within the Software Development category of DaniWeb, a massive community of 391,982 software developers, web developers, Internet marketers, and tech gurus who are all enthusiastic about making contacts, networking, and learning from each other. In fact, there are 4,166 IT professionals currently interacting right now! Registration is free, only takes a minute and lets you enjoy all of the interactive features of the site.
Please support our C advertiser:
Views: 394 | Replies: 7
Reply
Join Date: Oct 2006
Posts: 95
Reputation: edek is an unknown quantity at this point 
Rep Power: 2
Solved Threads: 0
edek's Avatar
edek edek is offline Offline
Junior Poster in Training

ftell() fclose() and FILE* f = NULL

  #1  
May 9th, 2008
  1. FILE* f = NULL;
  2. fclose(f);
Terminates with: 'No source available for "fclose@@GLIBC_2.1() " '

  1. FILE* f = NULL;
  2. ftell(f);
Terminates with: 'No source available for "ftell()"'

Why those functions does not return error value but terminate whole program? How can I safely tell if file is opened in C and close it???

If variable of type 'FILE*' is passed to my function I need to know the state of the file and be able to close.
Any idea?
Last edited by edek : May 9th, 2008 at 8:58 am.
AddThis Social Bookmark Button
Reply With Quote  
Join Date: Feb 2008
Location: Seattle
Posts: 699
Reputation: jephthah is a jewel in the rough jephthah is a jewel in the rough jephthah is a jewel in the rough 
Rep Power: 4
Solved Threads: 45
jephthah's Avatar
jephthah jephthah is offline Offline
Practically a Master Poster

Re: ftell() fclose() and FILE* f = NULL

  #2  
May 9th, 2008
what did you expect it to do?

you're trying to do the close and tell function on a NULL pointer.

now think about that for a minute, and you should have your answer.



.
Last edited by jephthah : May 9th, 2008 at 12:52 pm.
Reply With Quote  
Join Date: Dec 2005
Posts: 3,261
Reputation: Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of 
Rep Power: 20
Solved Threads: 368
Colleague
Salem's Avatar
Salem Salem is offline Offline
void main'ers are DOOMed

Re: ftell() fclose() and FILE* f = NULL

  #3  
May 9th, 2008
> Terminates with: 'No source available for "fclose@@GLIBC_2.1() " '
You get these in debug builds because the code for fclose uses assert() to validate the input parameters.

If you were in a debugger at the time, you'd know exactly where to start looking.

In this case, fclose() is likely to begin with
assert( fp != NULL );
Release builds have no assert() statements, so it would just return whatever the spec says fclose() should return if passed NULL.
If you dance barefoot on the broken glass of undefined behaviour, you've got to expect the occasional cut.
Do not PM me for help; You'll be ignored, or told to learn to read.
Do not ask me if I'm muslim - I'm not. Nor do I care about yours or anyone else's mysticism. Religion is a matrix, take the RED PILL.
Reply With Quote  
Join Date: Feb 2008
Location: Seattle
Posts: 699
Reputation: jephthah is a jewel in the rough jephthah is a jewel in the rough jephthah is a jewel in the rough 
Rep Power: 4
Solved Threads: 45
jephthah's Avatar
jephthah jephthah is offline Offline
Practically a Master Poster

Re: ftell() fclose() and FILE* f = NULL

  #4  
May 9th, 2008
well, i just learned something.
Reply With Quote  
Join Date: Oct 2006
Posts: 95
Reputation: edek is an unknown quantity at this point 
Rep Power: 2
Solved Threads: 0
edek's Avatar
edek edek is offline Offline
Junior Poster in Training

Re: ftell() fclose() and FILE* f = NULL

  #5  
May 10th, 2008
Originally Posted by Salem View Post
Release builds have no assert() statements, so it would just return whatever the spec says fclose() should return if passed NULL.

Actually, it terminates in release build. It should return error value, though. It might be some internal inconsistency of the implementation of C lib I am using (glibc2.1).
Last edited by edek : May 10th, 2008 at 8:29 am.
Reply With Quote  
Join Date: Dec 2005
Posts: 3,261
Reputation: Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of Salem has much to be proud of 
Rep Power: 20
Solved Threads: 368
Colleague
Salem's Avatar
Salem Salem is offline Offline
void main'ers are DOOMed

Re: ftell() fclose() and FILE* f = NULL

  #6  
May 10th, 2008
> Actually, it terminates in release build.
Is that because it detected NULL and cleanly exited, or dereferenced NULL and bombed?
If you dance barefoot on the broken glass of undefined behaviour, you've got to expect the occasional cut.
Do not PM me for help; You'll be ignored, or told to learn to read.
Do not ask me if I'm muslim - I'm not. Nor do I care about yours or anyone else's mysticism. Religion is a matrix, take the RED PILL.
Reply With Quote  
Join Date: Oct 2006
Posts: 95
Reputation: edek is an unknown quantity at this point 
Rep Power: 2
Solved Threads: 0
edek's Avatar
edek edek is offline Offline
Junior Poster in Training

Re: ftell() fclose() and FILE* f = NULL

  #7  
May 10th, 2008
Originally Posted by Salem View Post
Is that because it detected NULL and cleanly exited, or dereferenced NULL and bombed?

It seems to cleanly exit with the value -1. It does not return value to indicate error, it exits the whole application with value -1.
Reply With Quote  
Join Date: Oct 2006
Posts: 95
Reputation: edek is an unknown quantity at this point 
Rep Power: 2
Solved Threads: 0
edek's Avatar
edek edek is offline Offline
Junior Poster in Training

Re: ftell() fclose() and FILE* f = NULL

  #8  
May 10th, 2008
I've found something like (http://www.stanford.edu/~thathoo/cur...io.h/code.html line 204):

  1. /*This function is a possible cancellation point and therefore not marked with __THROW. */
  2. extern int fclose (FILE *__stream);
What does 'function is a possible cancellation point' mean?? Does it mean that it can cancel whole application on error?
Last edited by edek : May 10th, 2008 at 1:21 pm.
Reply With Quote  
Reply

Only community members can participate in forum threads. You must register or log in to contribute.

Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)

 

DaniWeb C Marketplace
Thread Tools Display Modes

Similar Threads
Other Threads in the C Forum

All times are GMT -4. The time now is 9:36 am.
Forum system based on vBulletin Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
©2003 - 2008 DaniWeb® LLC