ref: e33bd9c8f96394a89cd82c24c1db8b87009d324f
dir: /DoConfig/fltk/src/Fl_Browser_load.cxx/
// // "$Id$" // // File loading routines for the Fast Light Tool Kit (FLTK). // // Copyright 1998-2010 by Bill Spitzak and others. // // This library is free software. Distribution and use rights are outlined in // the file "COPYING" which should have been included with this file. If this // file is missing or damaged, see the license at: // // http://www.fltk.org/COPYING.php // // Please report all bugs and problems on the following page: // // http://www.fltk.org/str.php // #include <FL/Fl.H> #include <FL/Fl_Browser.H> #include <stdio.h> #include <FL/fl_utf8.h> /** Clears the browser and reads the file, adding each line from the file to the browser. If the filename is NULL or a zero-length string then this just clears the browser. This returns zero if there was any error in opening or reading the file, in which case errno is set to the system error. The data() of each line is set to NULL. \param[in] filename The filename to load \returns 1 if OK, 0 on error (errno has reason) \see add() */ int Fl_Browser::load(const char *filename) { #define MAXFL_BLINE 1024 char newtext[MAXFL_BLINE]; int c; int i; clear(); if (!filename || !(filename[0])) return 1; FILE *fl = fl_fopen(filename,"r"); if (!fl) return 0; i = 0; do { c = getc(fl); if (c == '\n' || c <= 0 || i>=(MAXFL_BLINE-1)) { newtext[i] = 0; add(newtext); i = 0; } else { newtext[i++] = c; } } while (c >= 0); fclose(fl); return 1; } // // End of "$Id$". //