| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343 | /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- *//* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is Mozilla Communicator client code, released * March 31, 1998. * * The Initial Developer of the Original Code is * Netscape Communications Corporation. * Portions created by the Initial Developer are Copyright (C) 1998-1999 * the Initial Developer. All Rights Reserved. * * Contributor(s): *   Doug Turner <[email protected]> *   Christopher Blizzard <[email protected]> *   Darin Fisher <[email protected]> * * Alternatively, the contents of this file may be used under the terms of * either of the GNU General Public License Version 2 or later (the "GPL"), * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */#include "nsISupports.idl"interface nsISimpleEnumerator;/** * This is the only correct cross-platform way to specify a file. * Strings are not such a way. If you grew up on windows or unix, you * may think they are.  Welcome to reality. * * All methods with string parameters have two forms.  The preferred * form operates on UCS-2 encoded characters strings.  An alternate * form operates on characters strings encoded in the "native" charset. * * A string containing characters encoded in the native charset cannot * be safely passed to javascript via xpconnect.  Therefore, the "native * methods" are not scriptable.  * * @status FROZEN */[scriptable, uuid(c8c0a080-0868-11d3-915f-d9d889d48e3c)]interface nsIFile : nsISupports{    /**     *  Create Types     *     *  NORMAL_FILE_TYPE - A normal file.     *  DIRECTORY_TYPE   - A directory/folder.     */    const unsigned long NORMAL_FILE_TYPE = 0;    const unsigned long DIRECTORY_TYPE   = 1;    /**     *  append[Native]     *     *  This function is used for constructing a descendent of the     *  current nsIFile.     *     *   @param node     *       A string which is intended to be a child node of the nsIFile.     *       For the |appendNative| method, the node must be in the native     *       filesystem charset.     */    void append(in AString node);    [noscript] void appendNative(in ACString node);    /**     *  Normalize the pathName (e.g. removing .. and . components on Unix).     */    void normalize();    /**     *  create     *     *  This function will create a new file or directory in the     *  file system. Any nodes that have not been created or     *  resolved, will be.  If the file or directory already     *  exists create() will return NS_ERROR_FILE_ALREADY_EXISTS.     *     *   @param type     *       This specifies the type of file system object     *       to be made.  The only two types at this time     *       are file and directory which are defined above.     *       If the type is unrecongnized, we will return an     *       error (NS_ERROR_FILE_UNKNOWN_TYPE).     *     *   @param permissions     *       The unix style octal permissions.  This may     *       be ignored on systems that do not need to do     *       permissions.     */    void create(in unsigned long type, in unsigned long permissions);    /**     *  Accessor to the leaf name of the file itself.           *  For the |nativeLeafName| method, the nativeLeafName must      *  be in the native filesystem charset.     */    attribute AString leafName;    [noscript] attribute ACString nativeLeafName;    /**     *  copyTo[Native]     *     *  This will copy this file to the specified newParentDir.     *  If a newName is specified, the file will be renamed.     *  If 'this' is not created we will return an error     *  (NS_ERROR_FILE_TARGET_DOES_NOT_EXIST).     *     *  copyTo may fail if the file already exists in the destination      *  directory.     *     *  copyTo will NOT resolve aliases/shortcuts during the copy.     *     *   @param newParentDir     *       This param is the destination directory. If the     *       newParentDir is null, copyTo() will use the parent     *       directory of this file. If the newParentDir is not     *       empty and is not a directory, an error will be     *       returned (NS_ERROR_FILE_DESTINATION_NOT_DIR). For the      *       |CopyToNative| method, the newName must be in the      *       native filesystem charset.     *     *   @param newName     *       This param allows you to specify a new name for     *       the file to be copied. This param may be empty, in     *       which case the current leaf name will be used.     */    void copyTo(in nsIFile newParentDir, in AString newName);    [noscript] void CopyToNative(in nsIFile newParentDir, in ACString newName);    /**     *  copyToFollowingLinks[Native]     *     *  This function is identical to copyTo with the exception that,     *  as the name implies, it follows symbolic links.  The XP_UNIX     *  implementation always follow symbolic links when copying.  For      *  the |CopyToFollowingLinks| method, the newName must be in the      *  native filesystem charset.     */    void copyToFollowingLinks(in nsIFile newParentDir, in AString newName);    [noscript] void copyToFollowingLinksNative(in nsIFile newParentDir, in ACString newName);    /**     *  moveTo[Native]     *     *  A method to move this file or directory to newParentDir.     *  If a newName is specified, the file or directory will be renamed.     *  If 'this' is not created we will return an error     *  (NS_ERROR_FILE_TARGET_DOES_NOT_EXIST).     *  If 'this' is a file, and the destination file already exists, moveTo     *  will replace the old file.     *     *  moveTo will NOT resolve aliases/shortcuts during the copy.     *  moveTo will do the right thing and allow copies across volumes.     *  moveTo will return an error (NS_ERROR_FILE_DIR_NOT_EMPTY) if 'this' is     *  a directory and the destination directory is not empty.     *  moveTo will return an error (NS_ERROR_FILE_ACCESS_DENIED) if 'this' is     *  a directory and the destination directory is not writable.     *     *   @param newParentDir     *       This param is the destination directory. If the     *       newParentDir is empty, moveTo() will rename the file     *       within its current directory. If the newParentDir is     *       not empty and does not name a directory, an error will     *       be returned (NS_ERROR_FILE_DESTINATION_NOT_DIR).  For      *       the |moveToNative| method, the newName must be in the      *       native filesystem charset.     *     *   @param newName     *       This param allows you to specify a new name for     *       the file to be moved. This param may be empty, in     *       which case the current leaf name will be used.     */    void moveTo(in nsIFile newParentDir, in AString newName);    [noscript] void moveToNative(in nsIFile newParentDir, in ACString newName);    /**     *  This will try to delete this file.  The 'recursive' flag     *  must be PR_TRUE to delete directories which are not empty.     *     *  This will not resolve any symlinks.     */    void remove(in boolean recursive);    /**     *  Attributes of nsIFile.     */    attribute unsigned long permissions;    attribute unsigned long permissionsOfLink;    /**     *  File Times are to be in milliseconds from     *  midnight (00:00:00), January 1, 1970 Greenwich Mean     *  Time (GMT).     */    attribute PRInt64 lastModifiedTime;    attribute PRInt64 lastModifiedTimeOfLink;    /**     *  WARNING!  On the Mac, getting/setting the file size with nsIFile     *  only deals with the size of the data fork.  If you need to     *  know the size of the combined data and resource forks use the     *  GetFileSizeWithResFork() method defined on nsILocalFileMac.     */    attribute PRInt64 fileSize;    readonly attribute PRInt64 fileSizeOfLink;    /**     *  target & path     *     *  Accessor to the string path.  The native version of these     *  strings are not guaranteed to be a usable path to pass to     *  NSPR or the C stdlib.  There are problems that affect     *  platforms on which a path does not fully specify a file     *  because two volumes can have the same name (e.g., XP_MAC).     *  This is solved by holding "private", native data in the     *  nsIFile implementation.  This native data is lost when     *  you convert to a string.     *     *      DO NOT PASS TO USE WITH NSPR OR STDLIB!     *     *  target     *      Find out what the symlink points at.  Will give error     *      (NS_ERROR_FILE_INVALID_PATH) if not a symlink.     *     *  path     *      Find out what the nsIFile points at.     *     *  Note that the ACString attributes are returned in the      *  native filesystem charset.     *     */    readonly attribute AString target;    [noscript] readonly attribute ACString nativeTarget;    readonly attribute AString path;    [noscript] readonly attribute ACString nativePath;    boolean exists();    boolean isWritable();    boolean isReadable();    boolean isExecutable();    boolean isHidden();    boolean isDirectory();    boolean isFile();    boolean isSymlink();    /**     * Not a regular file, not a directory, not a symlink.     */    boolean isSpecial();    /**     *  createUnique     *       *  This function will create a new file or directory in the     *  file system. Any nodes that have not been created or     *  resolved, will be.  If this file already exists, we try     *  variations on the leaf name "suggestedName" until we find     *  one that did not already exist.     *     *  If the search for nonexistent files takes too long     *  (thousands of the variants already exist), we give up and     *  return NS_ERROR_FILE_TOO_BIG.     *     *   @param type     *       This specifies the type of file system object     *       to be made.  The only two types at this time     *       are file and directory which are defined above.     *       If the type is unrecongnized, we will return an     *       error (NS_ERROR_FILE_UNKNOWN_TYPE).     *     *   @param permissions     *       The unix style octal permissions.  This may     *       be ignored on systems that do not need to do     *       permissions.     */    void createUnique(in unsigned long type, in unsigned long permissions);    /**      * clone()      *      * This function will allocate and initialize a nsIFile object to the      * exact location of the |this| nsIFile.      *      *   @param file      *          A nsIFile which this object will be initialize      *          with.      *      */    nsIFile clone();    /**     *  Will determine if the inFile equals this.     */    boolean equals(in nsIFile inFile);    /**     *  Will determine if inFile is a descendant of this file     *  If |recur| is true, look in subdirectories too     */    boolean contains(in nsIFile inFile, in boolean recur);    /**     *  Parent will be null when this is at the top of the volume.     */    readonly attribute nsIFile parent;        /**     *  Returns an enumeration of the elements in a directory. Each     *  element in the enumeration is an nsIFile.     *     *   @return NS_ERROR_FILE_NOT_DIRECTORY if the current nsIFile does     *           not specify a directory.     */    readonly attribute nsISimpleEnumerator directoryEntries;};%{C++#ifdef MOZILLA_INTERNAL_API#include "nsDirectoryServiceUtils.h"#endif%}
 |