| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266 |
- //
- // "$Id: Fl_Native_File_Chooser.H 11681 2016-04-23 06:27:31Z manolo $"
- //
- // FLTK native OS file chooser widget
- //
- // Copyright 1998-2016 by Bill Spitzak and others.
- // Copyright 2004 Greg Ercolano.
- //
- // 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
- //
- /** \file
- Fl_Native_File_Chooser widget. */
- /* Implementation note:
-
- class Fl_Native_File_Chooser <== public API used by applications
-
- class Fl_Native_File_Chooser_Driver <== virtual API that a platform may implement
- this API has a do-nothing default implementation
-
- class Fl_Native_File_Chooser_FLTK_Driver <== this API implementation is the default FLTK file chooser
- class Fl_GTK_Native_File_Chooser_Driver <== this API implementation runs a GTK file chooser
- it is determined at run-time if the GTK dynamic libraries are available
-
- class Fl_Quartz_Native_File_Chooser_Driver <== this API implementation runs a Mac OS X file chooser
- class Fl_WinAPI_Native_File_Chooser_Driver <== this API implementation runs a MSWindows file chooser
-
-
- Each platform must implement the constructor of the Fl_Native_File_Chooser class.
- This particular implementation:
-
- Fl_Native_File_Chooser::Fl_Native_File_Chooser(int val) {
- platform_fnfc = new Fl_Native_File_Chooser_FLTK_Driver(val);
- }
-
- can be used by any platform.
- No more code is required. The cross-platform Fl_Native_File_Chooser_FLTK.cxx file must be compiled in libfltk,
- and the default FLTK file chooser will be used.
-
- This other implementation:
- Fl_Native_File_Chooser::Fl_Native_File_Chooser(int val) {
- platform_fnfc = 0;
- }
- can be used by a platform that needs no file chooser.
- */
- #ifndef FL_NATIVE_FILE_CHOOSER_H
- #define FL_NATIVE_FILE_CHOOSER_H
- #include <FL/Fl_Export.H>
- #include <FL/Fl_File_Chooser.H>
- class Fl_Native_File_Chooser_Driver;
- /**
- This class lets an FLTK application easily and consistently access
- the operating system's native file chooser. Some operating systems
- have very complex and specific file choosers that many users want
- access to specifically, instead of FLTK's default file chooser(s).
-
- In cases where there is no native file browser, FLTK's own file browser
- is used instead.
-
- To use this widget, use the following include in your code:
- \code
- #include <FL/Fl_Native_File_Chooser.H>
- \endcode
-
- The following example shows how to pick a single file:
- \code
- // Create and post the local native file chooser
- #include <FL/Fl_Native_File_Chooser.H>
- [..]
- Fl_Native_File_Chooser fnfc;
- fnfc.title("Pick a file");
- fnfc.type(Fl_Native_File_Chooser::BROWSE_FILE);
- fnfc.filter("Text\t*.txt\n"
- "C Files\t*.{cxx,h,c}");
- fnfc.directory("/var/tmp"); // default directory to use
- // Show native chooser
- switch ( fnfc.show() ) {
- case -1: printf("ERROR: %s\n", fnfc.errmsg()); break; // ERROR
- case 1: printf("CANCEL\n"); break; // CANCEL
- default: printf("PICKED: %s\n", fnfc.filename()); break; // FILE CHOSEN
- }
- \endcode
-
- The Fl_Native_File_Chooser widget transmits UTF-8 encoded filenames to its user. It is
- recommended to open files that may have non-ASCII names with the fl_fopen() or
- fl_open() utility functions that handle these names in a cross-platform way
- (whereas the standard fopen()/open() functions fail on the MSWindows platform
- to open files with a non-ASCII name).
-
- <B>Platform Specific Caveats</B>
-
- - Under X windows, and if Fl::OPTION_FNFC_USES_GTK has not been switched off,
- the widget attempts to use standard GTK file chooser dialogs if they are
- available at run-time on the platform, and falls back to use FLTK's Fl_File_Chooser if they are not.
- In the latter case, it's best if you call Fl_File_Icon::load_system_icons()
- at the start of main(), to enable the nicer looking file browser widgets.
- Use the static public attributes of class Fl_File_Chooser to localize
- the browser.
- - Some operating systems support certain OS specific options; see
- Fl_Native_File_Chooser::options() for a list.
-
- \image html Fl_Native_File_Chooser.png "The Fl_Native_File_Chooser on different platforms."
- \image latex Fl_Native_File_Chooser.png "The Fl_Native_File_Chooser on different platforms" width=14cm
-
- */
- class FL_EXPORT Fl_Native_File_Chooser {
- private:
- Fl_Native_File_Chooser_Driver *platform_fnfc;
- public:
- enum Type {
- BROWSE_FILE = 0, ///< browse files (lets user choose one file)
- BROWSE_DIRECTORY, ///< browse directories (lets user choose one directory)
- BROWSE_MULTI_FILE, ///< browse files (lets user choose multiple files)
- BROWSE_MULTI_DIRECTORY, ///< browse directories (lets user choose multiple directories)
- BROWSE_SAVE_FILE, ///< browse to save a file
- BROWSE_SAVE_DIRECTORY ///< browse to save a directory
- };
- enum Option {
- NO_OPTIONS = 0x0000, ///< no options enabled
- SAVEAS_CONFIRM = 0x0001, ///< Show native 'Save As' overwrite confirm dialog
- NEW_FOLDER = 0x0002, ///< Show 'New Folder' icon (if supported)
- PREVIEW = 0x0004, ///< enable preview mode (if supported)
- USE_FILTER_EXT = 0x0008 ///< Chooser filter pilots the output file extension (if supported)
- };
- static const char *file_exists_message;
-
- /**
- The constructor. Internally allocates the native widgets.
- Optional \p val presets the type of browser this will be,
- which can also be changed with type().
- */
- Fl_Native_File_Chooser(int val = BROWSE_FILE); // each platorm implements it
- ~Fl_Native_File_Chooser();
- void type(int t);
- int type() const ;
- void options(int o);
- int options() const;
- int count() const;
- const char *filename() const ;
- const char *filename(int i) const ;
- void directory(const char *val) ;
- const char *directory() const;
- void title(const char *t);
- const char* title() const;
- const char *filter() const ;
- void filter(const char *f);
- int filters() const ;
- void filter_value(int i) ;
- int filter_value() const ;
- void preset_file(const char*f) ;
- const char* preset_file() const;
- const char *errmsg() const ;
- int show() ;
- };
- /** Represents the interface between FLTK and a native file chooser.
- This class is only for internal use by the FLTK library.
- A platform that wants to provide a native file chooser implements all virtual methods
- of this class. Each platform supported by FLTK must also implement the constructor of the
- Fl_Native_File_Chooser class.
- */
- class Fl_Native_File_Chooser_Driver {
- protected:
- static void chrcat(char *s, char c);
- static char *strapp(char *s, const char *val);
- static char *strfree(char *val);
- static char *strnew(const char *val);
- public:
- Fl_Native_File_Chooser_Driver(int val) {}
- virtual ~Fl_Native_File_Chooser_Driver() {}
- virtual void type(int t) {}
- virtual int type() const {return 0;}
- virtual void options(int o) {}
- virtual int options() const {return 0;}
- virtual int count() const {return 0;}
- virtual const char *filename() const {return 0;}
- virtual const char *filename(int i) const {return 0;}
- virtual void directory(const char *val) {}
- virtual const char *directory() const {return 0;}
- virtual void title(const char *t) {}
- virtual const char* title() const {return 0;}
- virtual const char *filter() const {return 0;}
- virtual void filter(const char *f) {}
- virtual int filters() const {return 0;}
- virtual void filter_value(int i) {}
- virtual int filter_value() const {return 0;}
- virtual void preset_file(const char*f) {}
- virtual const char* preset_file() const {return 0;}
- virtual const char *errmsg() const {return 0;}
- virtual int show() {return 1;}
- };
- /** A cross-platform implementation of Fl_Native_File_Chooser_Driver.
- This implementation uses a Fl_File_Chooser object as file chooser.
-
- Any platform can support the Fl_Native_File_Chooser class by implementing
- its constructor as follows:
- \code
- Fl_Native_File_Chooser::Fl_Native_File_Chooser(int type) {
- platform_fnfc = new Fl_Native_File_Chooser_FLTK_Driver(type);
- }
- \endcode
- */
- class Fl_Native_File_Chooser_FLTK_Driver : public Fl_Native_File_Chooser_Driver {
- private:
- void errmsg(const char *msg);
- int type_fl_file(int val);
- int exist_dialog();
- void parse_filter();
- protected:
- int _btype; // kind-of browser to show()
- int _options; // general options
- int _nfilters;
- char *_filter; // user supplied filter
- char *_parsedfilt; // parsed filter
- int _filtvalue; // selected filter
- char *_preset_file;
- char *_prevvalue; // Returned filename
- char *_directory;
- char *_errmsg; // error message
- Fl_File_Chooser *_file_chooser;
- public:
- Fl_Native_File_Chooser_FLTK_Driver(int val);
- virtual ~Fl_Native_File_Chooser_FLTK_Driver();
- virtual void type(int t);
- virtual int type() const ;
- virtual void options(int o);
- virtual int options() const;
- virtual int count() const;
- virtual const char *filename() const ;
- virtual const char *filename(int i) const ;
- virtual void directory(const char *val) ;
- virtual const char *directory() const;
- virtual void title(const char *t);
- virtual const char* title() const;
- virtual const char *filter() const ;
- virtual void filter(const char *f);
- virtual int filters() const ;
- virtual void filter_value(int i) ;
- virtual int filter_value() const ;
- virtual void preset_file(const char*f) ;
- virtual const char* preset_file() const;
- virtual const char *errmsg() const ;
- virtual int show() ;
- };
- #endif /*FL_NATIVE_FILE_CHOOSER_H*/
- //
- // End of "$Id: Fl_Native_File_Chooser.H 11681 2016-04-23 06:27:31Z manolo $".
- //
|