[GRASS-dev] (no subject)

Andruit at gmx.de Andruit at gmx.de
Wed Nov 19 09:28:49 EST 2008


It seems that the files are not closed, but I use

    if((elev_fd = G_open_cell_old (name, mapset)) < 0)
    G_fatal_error( _("can't open %s"), name);
   
    if((output_fd = G_open_cell_new(outname)) < 0)
    G_fatal_error( _("can't open outname %s"), outname);

to open the files and

    G_close_cell(output_fd);
    G_close_cell(elev_fd);

to close the files again.

Is there anything wrong?

Andi

Glynn Clements wrote:
> Andruit at gmx.de wrote:
>
>> I am writing a Grass programm which creates a raster, reads the values
>> of the raster map at certain points and creates a new rastermap having
>> the same name as the old one.
>>
>> I am using the function
>>
>> G_open_cell_new()  to overwrite the existing raster map.
>>
>> and the function
>>
>>  G_close_cell()
>>
>>
>> It works fine.
>>
>> But after about 1000 loops I get the following messsage.
>>
>> WARNING: opencell opening temp null file: no temp files available
>>
>> Does anyone know what it means. I have enough space left in my ./tmp
>> folder. And I also have write permissions on it.
>
> It probably means that files aren't getting closed, so you are
> exceeding the limit on the number of open files per process (by
> default 1024, check with ulimit -n).
>
> On Linux, you can check which files a process has open by looking in
> the /proc/<pid>/fd directory, where <pid> is the PID of the process.
>
> If you're modifying a map "in-place", you'll need to close and re-open
> the input map in order to see the changes. Opening a map for write
> creates a temporary file, which is renamed over the original when
> closed. If the original cell/fcell file is still open for read at that
> point, it will still exist and still be open (it will show up as
> "(deleted)" in /proc/<pid>/fd).
>


-- 
Ist Ihr Browser Vista-kompatibel? Jetzt die neuesten 
Browser-Versionen downloaden: http://www.gmx.net/de/go/browser


More information about the grass-dev mailing list