From Bennu Wiki
Jump to navigation Jump to search


A FileHandle is an identifier for a file, for use in functions requiring a FileHandle, like fread(), fwrite() and fclose().

Consider the following code:

handle = fopen("file.txt",O_READ);

The fopen() function will try to open the "file.txt" for reading. If it fails to open the file for whatever reason (e.g. file not found or insufficient user rights) handle will have the value of 0. If opening the file for reading succeeded, the handle will have a value other than 0. What the value will be depends on the OS and runtime circumstances. It represents an OS internal pointer to the actual file.

The file will remain open for reading, until it is closed using fclose():


This is important, because else the operating system and other programs think you are still using it and this can result in them not being able to open the file.


So always check if a file has been successfully opened and close the file when you are done with it.

import "mod_file"
import "mod_say"

Process Main()
    int handle;   // handle for the loaded file
    string first_line; // here's where the first line of the file will go

    // Open the file "file.txt"
    handle = fopen( "file.txt",O_READ);

    if (handle == 0)
        say( "Could not open file" );

    // Read the first line form the file
    first_line = fgets(handle);

    // Output the read line
    say( "Read from file:" );
    say('"' + first_line + '"');

    // Close the file (important!)


Used in example: fopen(), say(), fgets(), fclose()

Functions Fclose()Feof()Fexists()Fflush()Fgets()File()Flength()Fmove()Fopen()Fputs()Fread()Fremove()Frewind()Fseek()Ftell()Fwrite()Load()Save()