1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     interface of wxFileName 
   4 // Author:      wxWidgets team 
   6 // Licence:     wxWindows license 
   7 ///////////////////////////////////////////////////////////////////////////// 
  10 /** The various values for the path format: this mainly affects the path 
  11     separator but also whether or not the path has the drive part 
  14     See wxFileName for more info. 
  18     wxPATH_NATIVE 
= 0,      //!< the path format for the current platform. 
  20     wxPATH_BEOS 
= wxPATH_UNIX
, 
  23     wxPATH_WIN 
= wxPATH_DOS
, 
  24     wxPATH_OS2 
= wxPATH_DOS
, 
  27     wxPATH_MAX   
//!< Not a valid value for specifying path format 
  31 /** The kind of normalization to do with the file name: these values can be 
  32     or'd together to perform several operations at once. 
  33     See wxFileName::Normalize() for more info. 
  37     wxPATH_NORM_ENV_VARS 
= 0x0001,  //!< replace env vars with their values. 
  38     wxPATH_NORM_DOTS     
= 0x0002,  //!< squeeze all .. and . and prepend cwd. 
  39     wxPATH_NORM_TILDE    
= 0x0004,  //!< Unix only: replace ~ and ~user. 
  40     wxPATH_NORM_CASE     
= 0x0008,  //!< if case insensitive => tolower. 
  41     wxPATH_NORM_ABSOLUTE 
= 0x0010,  //!< make the path absolute. 
  42     wxPATH_NORM_LONG 
=     0x0020,  //!< make the path the long form. 
  43     wxPATH_NORM_SHORTCUT 
= 0x0040,  //!< resolve the shortcut, if it is a shortcut. 
  44     wxPATH_NORM_ALL      
= 0x00ff & ~wxPATH_NORM_CASE
 
  48     The return value of wxFileName::GetSize() in case of error. 
  50 wxULongLong wxInvalidSize
; 
  56     wxFileName encapsulates a file name. 
  58     This class serves two purposes: first, it provides the functions to split the 
  59     file names into components and to recombine these components in the full file 
  60     name which can then be passed to the OS file functions 
  61     (and @ref group_funcmacro_file "wxWidgets functions" wrapping them). 
  62     Second, it includes the functions for working with the files itself. Note that 
  63     to change the file data you should use wxFile class instead. 
  64     wxFileName provides functions for working with the file attributes. 
  66     When working with directory names (i.e. without filename and extension) 
  67     make sure not to misuse the file name part of this class with the last 
  68     directory. Instead initialize the wxFileName instance like this: 
  71     wxFileName dirname( "C:\mydir", "" ); 
  72     MyMethod( dirname.GetPath() ); 
  75     The same can be done using the static method wxFileName::DirName(): 
  78     wxFileName dirname = wxFileName::DirName( "C:\mydir" ); 
  79     MyMethod( dirname.GetPath() ); 
  82     Accordingly, methods dealing with directories or directory names like 
  83     wxFileName::IsDirReadable() use wxFileName::GetPath() whereas methods dealing 
  84     with file names like wxFileName::IsFileReadable() use wxFileName::GetFullPath(). 
  86     If it is not known wether a string contains a directory name or a complete 
  87     file name (such as when interpreting user input) you need to use the static 
  88     function wxFileName::DirExists() (or its identical variants wxDir::Exists() and 
  89     wxDirExists()) and construct the wxFileName instance accordingly. 
  90     This will only work if the directory actually exists, of course: 
  94     // get input from user 
  97     if (wxDirExists(user_input)) 
  98         fname.AssignDir( user_input ); 
 100         fname.Assign( user_input ); 
 103     Please note that many wxFileName methods accept the path format argument 
 104     which is by @c wxPATH_NATIVE by default meaning to use the path format 
 105     native for the current platform. 
 106     The path format affects the operation of wxFileName functions in several ways: 
 107     first and foremost, it defines the path separator character to use, but it 
 108     also affects other things such as whether the path has the drive part or not. 
 109     See wxPathFormat for more info. 
 112     @section filename_format File name format 
 114     wxFileName currently supports the file names in the Unix, DOS/Windows, 
 115     Mac OS and VMS formats. Although these formats are quite different, 
 116     wxFileName tries to treat them all in the same generic way. 
 117     It supposes that all file names consist of the following parts: the volume 
 118     (also known as drive under Windows or device under VMS), the path which is 
 119     a sequence of directory names separated by the path separators and the full 
 120     filename itself which, in turn, is composed from the base file name and the 
 121     extension. All of the individual components of the file name may be empty 
 122     and, for example, the volume name is always empty under Unix, but if they 
 123     are all empty simultaneously, the filename object is considered to be in an 
 124     invalid state and wxFileName::IsOk() returns false for it. 
 126     File names can be case-sensitive or not, the function wxFileName::IsCaseSensitive() 
 127     allows to determine this. The rules for determining whether the file name is 
 128     absolute or relative also depend on the file name format and the only portable way 
 129     to answer this question is to use wxFileName::IsAbsolute() or wxFileName::IsRelative() 
 132     Note that on Windows,"X:" refers to the current working directory on drive X. 
 133     Therefore, a wxFileName instance constructed from for example "X:dir/file.ext" 
 134     treats the portion beyond drive separator as being relative to that directory. 
 135     To ensure that the filename is absolute, you may use wxFileName::MakeAbsolute(). 
 136     There is also an inverse function wxFileName::MakeRelativeTo() which undoes 
 137     what wxFileName::Normalize(wxPATH_NORM_DOTS) does. 
 138     Other functions returning information about the file format provided by this 
 139     class are wxFileName::GetVolumeSeparator(), wxFileName::IsPathSeparator(). 
 142     @section filename_construction File name construction 
 144     You can initialize a wxFileName instance using one of the following functions: 
 146     @li wxFileName::wxFileName() 
 147     @li wxFileName::Assign() 
 148     @li wxFileName::AssignCwd() 
 149     @li wxFileName::AssignDir() 
 150     @li wxFileName::AssignHomeDir() 
 151     @li wxFileName::AssignTempFileName() 
 152     @li wxFileName::DirName() 
 153     @li wxFileName::FileName() 
 154     @li wxFileName::operator=() 
 157     @section filename_tests File name tests 
 159     Before doing other tests, you should use wxFileName::IsOk() to verify that 
 160     the filename is well defined. If it is, FileExists() can be used to test whether 
 161     a file with such name exists and wxFileName::DirExists() can be used to test 
 162     for directory existence. 
 163     File names should be compared using the wxFileName::SameAs() method or 
 164     wxFileName::operator==(). For testing basic access modes, you can use: 
 166     @li wxFileName::IsDirWritable() 
 167     @li wxFileName::IsDirReadable() 
 168     @li wxFileName::IsFileWritable() 
 169     @li wxFileName::IsFileReadable() 
 170     @li wxFileName::IsFileExecutable() 
 173     @section filename_components File name components 
 175     These functions allow to examine and modify the individual directories 
 178     @li wxFileName::AppendDir() 
 179     @li wxFileName::InsertDir() 
 180     @li wxFileName::GetDirCount() 
 181     @li wxFileName::PrependDir() 
 182     @li wxFileName::RemoveDir() 
 183     @li wxFileName::RemoveLastDir() 
 185     To change the components of the file name individually you can use the 
 188     @li wxFileName::GetExt() 
 189     @li wxFileName::GetName() 
 190     @li wxFileName::GetVolume() 
 191     @li wxFileName::HasExt() 
 192     @li wxFileName::HasName() 
 193     @li wxFileName::HasVolume() 
 194     @li wxFileName::SetExt() 
 195     @li wxFileName::ClearExt() 
 196     @li wxFileName::SetEmptyExt() 
 197     @li wxFileName::SetName() 
 198     @li wxFileName::SetVolume() 
 200     You can initialize a wxFileName instance using one of the following functions: 
 203     @section filename_operations File name operations 
 205     These methods allow to work with the file creation, access and modification 
 206     times. Note that not all filesystems under all platforms implement these times 
 207     in the same way. For example, the access time under Windows has a resolution of 
 208     one day (so it is really the access date and not time). The access time may be 
 209     updated when the file is executed or not depending on the platform. 
 211     @li wxFileName::GetModificationTime() 
 212     @li wxFileName::GetTimes() 
 213     @li wxFileName::SetTimes() 
 214     @li wxFileName::Touch() 
 216     Other file system operations functions are: 
 218     @li wxFileName::Mkdir() 
 219     @li wxFileName::Rmdir() 
 236     wxFileName(const wxFileName
& filename
); 
 239         Constructor taking a full filename. 
 241         If it terminates with a '/', a directory path is constructed 
 242         (the name will be empty), otherwise a file name and extension 
 243         are extracted from it. 
 245     wxFileName(const wxString
& fullpath
, 
 246                wxPathFormat format 
= wxPATH_NATIVE
); 
 249         Constructor a directory name and file name. 
 251     wxFileName(const wxString
& path
, const wxString
& name
, 
 252                wxPathFormat format 
= wxPATH_NATIVE
); 
 255         Constructor from a directory name, base file name and extension. 
 257     wxFileName(const wxString
& path
, const wxString
& name
, 
 259                wxPathFormat format 
= wxPATH_NATIVE
); 
 262         Constructor from a volume name, a directory name, base file name and extension. 
 264     wxFileName(const wxString
& volume
, const wxString
& path
, 
 265                const wxString
& name
, 
 267                wxPathFormat format 
= wxPATH_NATIVE
); 
 270         Appends a directory component to the path. This component should contain a 
 271         single directory name level, i.e. not contain any path or volume separators nor 
 272         should it be empty, otherwise the function does nothing (and generates an 
 273         assert failure in debug build). 
 275     void AppendDir(const wxString
& dir
); 
 278         Creates the file name from another filename object. 
 280     void Assign(const wxFileName
& filepath
); 
 283         Creates the file name from a full file name with a path. 
 285     void Assign(const wxString
& fullpath
, 
 286                 wxPathFormat format 
= wxPATH_NATIVE
); 
 289         Creates the file name from volumne, path, name and extension. 
 291     void Assign(const wxString
& volume
, const wxString
& path
, 
 292                 const wxString
& name
, 
 295                 wxPathFormat format 
= wxPATH_NATIVE
); 
 298         Creates the file name from volumne, path, name and extension. 
 300     void Assign(const wxString
& volume
, const wxString
& path
, 
 301                 const wxString
& name
, 
 303                 wxPathFormat format 
= wxPATH_NATIVE
); 
 306         Creates the file name from file path and file name. 
 308     void Assign(const wxString
& path
, const wxString
& name
, 
 309                 wxPathFormat format 
= wxPATH_NATIVE
); 
 312         Creates the file name from path, name and extension. 
 314     void Assign(const wxString
& path
, const wxString
& name
, 
 316                 wxPathFormat format 
= wxPATH_NATIVE
); 
 319         Makes this object refer to the current working directory on the specified 
 320         volume (or current volume if @a volume is empty). 
 324     static void AssignCwd(const wxString
& volume 
= wxEmptyString
); 
 327         Sets this file name object to the given directory name. 
 328         The name and extension will be empty. 
 330     void AssignDir(const wxString
& dir
, 
 331                    wxPathFormat format 
= wxPATH_NATIVE
); 
 334         Sets this file name object to the home directory. 
 336     void AssignHomeDir(); 
 339         The function calls CreateTempFileName() to create a temporary file 
 340         and sets this object to the name of the file. 
 342         If a temporary file couldn't be created, the object is put into 
 343         an invalid state (see IsOk()). 
 345     void AssignTempFileName(const wxString
& prefix
); 
 348         The function calls CreateTempFileName() to create a temporary 
 349         file name and open @a fileTemp with it. 
 351         If the file couldn't be opened, the object is put into 
 352         an invalid state (see IsOk()). 
 354     void AssignTempFileName(const wxString
& prefix
, wxFile
* fileTemp
); 
 357         The function calls CreateTempFileName() to create a temporary 
 358         file name and open @a fileTemp with it. 
 360         If the file couldn't be opened, the object is put into 
 361         an invalid state (see IsOk()). 
 363     void AssignTempFileName(const wxString
& prefix
, wxFFile
* fileTemp
); 
 366         Reset all components to default, uninitialized state. 
 371         Removes the extension from the file name resulting in a 
 372         file name with no trailing dot. 
 374         @see SetExt(), SetEmptyExt() 
 379         Returns a temporary file name starting with the given @e prefix. 
 380         If the @a prefix is an absolute path, the temporary file is created in this 
 381         directory, otherwise it is created in the default system directory for the 
 382         temporary files or in the current directory. 
 384         If the function succeeds, the temporary file is actually created. 
 385         If @a fileTemp is not @NULL, this file will be opened using the name of 
 386         the temporary file. When possible, this is done in an atomic way ensuring that 
 387         no race condition occurs between the temporary file name generation and opening 
 388         it which could often lead to security compromise on the multiuser systems. 
 389         If @a fileTemp is @NULL, the file is only created, but not opened. 
 390         Under Unix, the temporary file will have read and write permissions for the 
 391         owner only to minimize the security problems. 
 394             Prefix to use for the temporary file name construction 
 396             The file to open or @NULL to just get the name 
 398         @return The full temporary file name or an empty string on error. 
 400     static wxString 
CreateTempFileName(const wxString
& prefix
, 
 401                                        wxFile
* fileTemp 
= NULL
); 
 404         Returns @true if the directory with this name exists. 
 406     bool DirExists() const; 
 409         Returns @true if the directory with this name exists. 
 411     static bool DirExists(const wxString
& dir
); 
 414         Returns the object corresponding to the directory with the given name. 
 415         The @a dir parameter may have trailing path separator or not. 
 417     static wxFileName 
DirName(const wxString
& dir
, 
 418                               wxPathFormat format 
= wxPATH_NATIVE
); 
 421         Returns @true if the file with this name exists. 
 425     bool FileExists() const; 
 428         Returns @true if the file with this name exists. 
 432     static bool FileExists(const wxString
& file
); 
 435         Returns the file name object corresponding to the given @e file. This 
 436         function exists mainly for symmetry with DirName(). 
 438     static wxFileName 
FileName(const wxString
& file
, 
 439                                wxPathFormat format 
= wxPATH_NATIVE
); 
 442         Retrieves the value of the current working directory on the specified volume. 
 443         If the volume is empty, the program's current working directory is returned for 
 446         @return The string containing the current working directory or an empty 
 451     static wxString 
GetCwd(const wxString
& volume 
= wxEmptyString
); 
 454         Returns the number of directories in the file name. 
 456     size_t GetDirCount() const; 
 459         Returns the directories in string array form. 
 461     const wxArrayString
& GetDirs() const; 
 464         Returns the file name extension. 
 466     wxString 
GetExt() const; 
 469         Returns the characters that can't be used in filenames and directory names 
 470         for the specified format. 
 472     static wxString 
GetForbiddenChars(wxPathFormat format 
= wxPATH_NATIVE
); 
 475         Returns the canonical path format for this platform. 
 477     static wxPathFormat 
GetFormat(wxPathFormat format 
= wxPATH_NATIVE
); 
 480         Returns the full name (including extension but excluding directories). 
 482     wxString 
GetFullName() const; 
 485         Returns the full path with name and extension. 
 487     wxString 
GetFullPath(wxPathFormat format 
= wxPATH_NATIVE
) const; 
 490         Returns the home directory. 
 492     static wxString 
GetHomeDir(); 
 495         Returns the size of the file in a human-readable form. 
 497         If the size could not be retrieved the @c failmsg string 
 498         is returned. In case of success, the returned string is 
 499         a floating-point number with @c precision decimal digits 
 500         followed by the size unit (B, kB, MB, GB, TB: respectively 
 501         bytes, kilobytes, megabytes, gigabytes, terabytes). 
 503     wxString 
GetHumanReadableSize(const wxString
& failmsg 
= "Not available", 
 504                                   int precision 
= 1) const; 
 507         Returns the size of the given number of bytes in a human-readable form. 
 509         If @a bytes is ::wxInvalidSize or zero, then @a nullsize is returned. 
 511         In case of success, the returned string is a floating-point number with 
 512         @a precision decimal digits followed by the size unit (B, kB, MB, GB, 
 513         TB: respectively bytes, kilobytes, megabytes, gigabytes, terabytes). 
 515     static wxString 
GetHumanReadableSize(const wxULongLong
& bytes
, 
 516                                          const wxString
& nullsize 
= "Not available", 
 520         Return the long form of the path (returns identity on non-Windows platforms). 
 522     wxString 
GetLongPath() const; 
 525         Returns the last time the file was last modified. 
 527     wxDateTime 
GetModificationTime() const; 
 530         Returns the name part of the filename (without extension). 
 534     wxString 
GetName() const; 
 537         Returns the path part of the filename (without the name or extension). 
 539         The possible flags values are: 
 541         - @b wxPATH_GET_VOLUME 
 542         Return the path with the volume (does nothing for the filename formats 
 543         without volumes), otherwise the path without volume part is returned. 
 545         - @b wxPATH_GET_SEPARATOR: 
 546         Return the path with the trailing separator, if this flag is not given 
 547         there will be no separator at the end of the path. 
 549         - @b wxPATH_NO_SEPARATOR: 
 550         Don't include the trailing separator in the returned string. This is 
 551         the default (the value of this flag is 0) and exists only for symmetry 
 552         with wxPATH_GET_SEPARATOR. 
 554     wxString 
GetPath(int flags 
= wxPATH_GET_VOLUME
, 
 555                      wxPathFormat format 
= wxPATH_NATIVE
) const; 
 558         Returns the usually used path separator for this format. 
 559         For all formats but @c wxPATH_DOS there is only one path separator anyhow, 
 560         but for DOS there are two of them and the native one, i.e. the backslash 
 561         is returned by this method. 
 563         @see GetPathSeparators() 
 565     static wxUniChar 
GetPathSeparator(wxPathFormat format 
= wxPATH_NATIVE
); 
 568         Returns the string containing all the path separators for this format. 
 569         For all formats but @c wxPATH_DOS this string contains only one character 
 570         but for DOS and Windows both @c '/' and @c '\' may be used as separators. 
 572         @see GetPathSeparator() 
 574     static wxString 
GetPathSeparators(wxPathFormat format 
= wxPATH_NATIVE
); 
 577         Returns the string of characters which may terminate the path part. 
 578         This is the same as GetPathSeparators() except for VMS 
 579         path format where ] is used at the end of the path part. 
 581     static wxString 
GetPathTerminators(wxPathFormat format 
= wxPATH_NATIVE
); 
 584         Returns the path with the trailing separator, useful for appending the name 
 587         This is the same as calling 
 589         GetPath(wxPATH_GET_VOLUME | wxPATH_GET_SEPARATOR, format) 
 592     wxString 
GetPathWithSep(wxPathFormat format 
= wxPATH_NATIVE
) const; 
 595         Return the short form of the path (returns identity on non-Windows platforms). 
 597     wxString 
GetShortPath() const; 
 600         Returns the size of the file If the file does not exist or its size could 
 601         not be read (because e.g. the file is locked by another process) the returned 
 602         value is ::wxInvalidSize. 
 604     wxULongLong 
GetSize() const; 
 607         Returns the size of the file If the file does not exist or its size could 
 608         not be read (because e.g. the file is locked by another process) the returned 
 609         value is ::wxInvalidSize. 
 611     const static wxULongLong 
GetSize(const wxString
& filename
); 
 614         Returns the directory used for temporary files. 
 616     static wxString 
GetTempDir(); 
 619         Returns the last access, last modification and creation times. 
 620         The last access time is updated whenever the file is read or written 
 621         (or executed in the case of Windows), last modification time is only 
 622         changed when the file is written to. 
 623         Finally, the creation time is indeed the time when the file was created 
 624         under Windows and the inode change time under Unix (as it is impossible to 
 625         retrieve the real file creation time there anyhow) which can also be changed 
 626         by many operations after the file creation. 
 628         If no filename or extension is specified in this instance of wxFileName 
 629         (and therefore IsDir() returns @true) then this function will return the 
 630         directory times of the path specified by GetPath(), otherwise the file 
 631         times of the file specified by GetFullPath(). 
 632         Any of the pointers may be @NULL if the corresponding time is not needed. 
 634         @return @true on success, @false if we failed to retrieve the times. 
 636     bool GetTimes(wxDateTime
* dtAccess
, wxDateTime
* dtMod
, 
 637                   wxDateTime
* dtCreate
) const; 
 640         Returns the string containing the volume for this file name, empty if it 
 641         doesn't have one or if the file system doesn't support volumes at all 
 644     wxString 
GetVolume() const; 
 647         Returns the string separating the volume from the path for this format. 
 649     static wxString 
GetVolumeSeparator(wxPathFormat format 
= wxPATH_NATIVE
); 
 652         This function builds a volume path string, for example "C:\\". 
 654         Implemented for the platforms which use drive letters, i.e. DOS, MSW 
 660             The drive letter, 'A' through 'Z' or 'a' through 'z'. 
 663             @c wxPATH_NO_SEPARATOR or @c wxPATH_GET_SEPARATOR to omit or include 
 664             the trailing path separator, the default is to include it. 
 666         @return Volume path string. 
 668     static wxString 
GetVolumeString(char drive
, int flags 
= wxPATH_GET_SEPARATOR
); 
 671         Returns @true if an extension is present. 
 676         Returns @true if a name is present. 
 678     bool HasName() const; 
 681         Returns @true if a volume specifier is present. 
 683     bool HasVolume() const; 
 686         Inserts a directory component before the zero-based position in the directory 
 687         list. Please see AppendDir() for important notes. 
 689     void InsertDir(size_t before
, const wxString
& dir
); 
 692         Returns @true if this filename is absolute. 
 694     bool IsAbsolute(wxPathFormat format 
= wxPATH_NATIVE
) const; 
 697         Returns @true if the file names of this type are case-sensitive. 
 699     static bool IsCaseSensitive(wxPathFormat format 
= wxPATH_NATIVE
); 
 702         Returns @true if this object represents a directory, @false otherwise 
 703         (i.e. if it is a file). 
 705         Note that this method doesn't test whether the directory or file really 
 706         exists, you should use DirExists() or FileExists() for this. 
 711         Returns @true if the directory component of this instance is an existing 
 712         directory and this process has read permissions on it. Read permissions 
 713         on a directory mean that you can list the directory contents but it 
 714         doesn't imply that you have read permissions on the files contained. 
 716     bool IsDirReadable() const; 
 719         Returns @true if the given @e dir is an existing directory and this process 
 720         has read permissions on it. Read permissions on a directory mean that you 
 721         can list the directory contents but it doesn't imply that you have read 
 722         permissions on the files contained. 
 724     static bool IsDirReadable(const wxString
& dir
); 
 727         Returns @true if the directory component of this instance 
 728         is an existing directory and this process has write permissions on it. 
 729         Write permissions on a directory mean that you can create new files in the 
 732     bool IsDirWritable() const; 
 735         Returns @true if the  given @a dir is an existing directory and this 
 736         process has write permissions on it. 
 737         Write permissions on a directory mean that you can create new files in the 
 740     static bool IsDirWritable(const wxString
& dir
); 
 743         Returns @true if a file with this name exists and if this process has execute 
 746     bool IsFileExecutable() const; 
 749         Returns @true if a file with this name exists and if this process has execute 
 752     static bool IsFileExecutable(const wxString
& file
); 
 755         Returns @true if a file with this name exists and if this process has read 
 758     bool IsFileReadable() const; 
 761         Returns @true if a file with this name exists and if this process has read 
 764     static bool IsFileReadable(const wxString
& file
); 
 767         Returns @true if a file with this name exists and if this process has write 
 770     bool IsFileWritable() const; 
 773         Returns @true if a file with this name exists and if this process has write 
 776     static bool IsFileWritable(const wxString
& file
); 
 779         Returns @true if the filename is valid, @false if it is not initialized yet. 
 780         The assignment functions and Clear() may reset the object to the uninitialized, 
 781         invalid state (the former only do it on failure). 
 786         Returns @true if the char is a path separator for this format. 
 788     static bool IsPathSeparator(wxChar ch
, 
 789                                 wxPathFormat format 
= wxPATH_NATIVE
); 
 792         Returns @true if this filename is not absolute. 
 794     bool IsRelative(wxPathFormat format 
= wxPATH_NATIVE
) const; 
 797         On Mac OS, gets the common type and creator for the given extension. 
 799     static bool MacFindDefaultTypeAndCreator(const wxString
& ext
, 
 804         On Mac OS, registers application defined extensions and their default type 
 807     static void MacRegisterDefaultTypeAndCreator(const wxString
& ext
, 
 812         On Mac OS, looks up the appropriate type and creator from the registration 
 815     bool MacSetDefaultTypeAndCreator(); 
 818         Make the file name absolute. 
 819         This is a shortcut for 
 821         wxFileName::Normalize(wxPATH_NORM_DOTS | wxPATH_NORM_ABSOLUTE | 
 822                               wxPATH_NORM_TILDE, cwd, format) 
 825         @see MakeRelativeTo(), Normalize(), IsAbsolute() 
 827     bool MakeAbsolute(const wxString
& cwd 
= wxEmptyString
, 
 828                       wxPathFormat format 
= wxPATH_NATIVE
); 
 831         This function tries to put this file name in a form relative to 
 833         In other words, it returns the file name which should be used to access 
 834         this file if the current directory were pathBase. 
 837             The directory to use as root, current directory is used by default 
 839             The file name format, native by default 
 841         @return @true if the file name has been changed, @false if we failed to do 
 842                 anything with it (currently this only happens if the file name 
 843                 is on a volume different from the volume specified by @a pathBase). 
 847     bool MakeRelativeTo(const wxString
& pathBase 
= wxEmptyString
, 
 848                         wxPathFormat format 
= wxPATH_NATIVE
); 
 854             The permissions for the newly created directory. 
 855             See the ::wxPosixPermissions enumeration for more info. 
 857             If the flags contain @c wxPATH_MKDIR_FULL flag, try to create each 
 858             directory in the path and also don't return an error if the target 
 859             directory already exists. 
 861         @return Returns @true if the directory was successfully created, @false 
 864     bool Mkdir(int perm 
= wxS_DIR_DEFAULT
, int flags 
= 0); 
 870             The directory to create 
 872             The permissions for the newly created directory. 
 873             See the ::wxPosixPermissions enumeration for more info. 
 875             If the flags contain @c wxPATH_MKDIR_FULL flag, try to create each 
 876             directory in the path and also don't return an error if the target 
 877             directory already exists. 
 879         @return Returns @true if the directory was successfully created, @false 
 882     static bool Mkdir(const wxString
& dir
, int perm 
= wxS_DIR_DEFAULT
, 
 886         Normalize the path. With the default flags value, the path will be 
 887         made absolute, without any ".." and "." and all environment 
 888         variables will be expanded in it. 
 891             The kind of normalization to do with the file name. It can be 
 892             any or-combination of the wxPathNormalize enumeration values. 
 894             If not empty, this directory will be used instead of current 
 895             working directory in normalization (see @c wxPATH_NORM_ABSOLUTE). 
 897             The file name format to use when processing the paths, native by default. 
 899         @return @true if normalization was successfully or @false otherwise. 
 901     bool Normalize(int flags 
= wxPATH_NORM_ALL
, 
 902                    const wxString
& cwd 
= wxEmptyString
, 
 903                    wxPathFormat format 
= wxPATH_NATIVE
); 
 906         Prepends a directory to the file path. 
 907         Please see AppendDir() for important notes. 
 909     void PrependDir(const wxString
& dir
); 
 912         Removes the specified directory component from the path. 
 916     void RemoveDir(size_t pos
); 
 919         Removes last directory component from the path. 
 921     void RemoveLastDir(); 
 924         Deletes the specified directory from the file system. 
 929         Deletes the specified directory from the file system. 
 931     static bool Rmdir(const wxString
& dir
); 
 934         Compares the filename using the rules of this platform. 
 936     bool SameAs(const wxFileName
& filepath
, 
 937                 wxPathFormat format 
= wxPATH_NATIVE
) const; 
 940         Changes the current working directory. 
 945         Changes the current working directory. 
 947     static bool SetCwd(const wxString
& cwd
); 
 950         Sets the extension of the file name to be an empty extension. 
 951         This is different from having no extension at all as the file 
 952         name will have a trailing dot after a call to this method. 
 954         @see SetExt(), ClearExt() 
 959         Sets the extension of the file name. 
 961         Setting an empty string as the extension will remove the extension 
 962         resulting in a file name without a trailing dot, unlike a call to 
 965         @see SetEmptyExt(), ClearExt() 
 967     void SetExt(const wxString
& ext
); 
 970         The full name is the file name and extension (but without the path). 
 972     void SetFullName(const wxString
& fullname
); 
 975         Sets the name part (without extension). 
 979     void SetName(const wxString
& name
); 
 982         Sets the file creation and last access/modification times (any of the pointers 
 985     bool SetTimes(const wxDateTime
* dtAccess
, 
 986                   const wxDateTime
* dtMod
, 
 987                   const wxDateTime
* dtCreate
); 
 990         Sets the volume specifier. 
 992     void SetVolume(const wxString
& volume
); 
 996         This function splits a full file name into components: the volume (with the 
 997         first version) path (including the volume in the second version), the base name 
1000         Any of the output parameters (@e volume, @e path, @a name or @e ext) may 
1001         be @NULL if you are not interested in the value of a particular component. 
1002         Also, @a fullpath may be empty on entry. 
1003         On return, @a path contains the file path (without the trailing separator), 
1004         @a name contains the file name and @a ext contains the file extension 
1005         without leading dot. All three of them may be empty if the corresponding 
1006         component is. The old contents of the strings pointed to by these parameters 
1007         will be overwritten in any case (if the pointers are not @NULL). 
1009         Note that for a filename "foo." the extension is present, as indicated by the 
1010         trailing dot, but empty. If you need to cope with such cases, you should use 
1011         @a hasExt instead of relying on testing whether @a ext is empty or not. 
1013     static void SplitPath(const wxString
& fullpath
, wxString
* volume
, 
1018                           wxPathFormat format 
= wxPATH_NATIVE
); 
1019     static void SplitPath(const wxString
& fullpath
, 
1024                           wxPathFormat format 
= wxPATH_NATIVE
); 
1025     static void SplitPath(const wxString
& fullpath
, 
1029                           wxPathFormat format 
= wxPATH_NATIVE
); 
1033         Splits the given @a fullpath into the volume part (which may be empty) and 
1034         the pure path part, not containing any volume. 
1038     static void SplitVolume(const wxString
& fullpath
, 
1041                             wxPathFormat format 
= wxPATH_NATIVE
); 
1044         Sets the access and modification times to the current moment. 
1049         Returns @true if the filenames are different. The string @e filenames 
1050         is interpreted as a path in the native filename format. 
1052     bool operator!=(const wxFileName
& filename
) const; 
1055         Returns @true if the filenames are different. The string @e filenames 
1056         is interpreted as a path in the native filename format. 
1058     bool operator!=(const wxString
& filename
) const; 
1061         Returns @true if the filenames are equal. The string @e filenames is 
1062         interpreted as a path in the native filename format. 
1064     bool operator==(const wxFileName
& filename
) const; 
1067         Returns @true if the filenames are equal. The string @e filenames is 
1068         interpreted as a path in the native filename format. 
1070     bool operator==(const wxString
& filename
) const; 
1073         Assigns the new value to this filename object. 
1075     wxFileName
& operator=(const wxFileName
& filename
); 
1078         Assigns the new value to this filename object. 
1080     wxFileName
& operator=(const wxString
& filename
);