Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 17 May 2006 12:36:40 -0600
From:      Lorin Lund <wbs@infowest.com>
To:        Andy Greenwood <greenwood.andy@gmail.com>
Cc:        FreeBSD Questions <freebsd-questions@freebsd.org>
Subject:   Re: C coding question
Message-ID:  <446B6D38.4070105@infowest.com>
In-Reply-To: <3ee9ca710605171109i57ae4064x702216a1619d6c41@mail.gmail.com>
References:  <3ee9ca710605171109i57ae4064x702216a1619d6c41@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
Andy Greenwood wrote:

> I am helping someone work on porting some code to Freebsd, and the
> code below works on Linux, but not on FreeBSD (compiles, but gives
> Segmentation Fault: 11). I'm not sure where the problem is, and any
> pointers would be much appreciated.
>
>        /* Check if we must stop */
>        if(tf_stat_file != NULL)
>        {
>            tf_stat = fopen(tf_stat_file, "r");
>            if (tf_stat != NULL)
>            {
>                /* Get state */
>                stat_state=fgetc(tf_stat);
>
>                /* Torrentflux asked to shutdown the torrent */
>                if (stat_state == '0')
>                {
>                    mustDie = 1;
>                }
>            }
>            fclose(tf_stat);
>        }
> _______________________________________________ 

I think I would move the
    fclose( tf_stat)
up a line.  No need to close a file that failed to open.  The fclose( ) 
acting on
a NULL pointer might be your error.




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?446B6D38.4070105>