diff options
| author | Einar Egilsson | 2011-08-26 14:37:27 +0200 | 
|---|---|---|
| committer | Einar Egilsson | 2011-08-26 14:37:27 +0200 | 
| commit | 3ac1838cba725705a96a9d7b65721b15f4ec67b1 (patch) | |
| tree | 6eea260d1e5882ba1031c5bb78bd2b9ac0884fb9 /components/interfaces/nsIFile.idl | |
| parent | 5aefd85d7975c8934b32a30a1dec68aa421cdee3 (diff) | |
Moved everything to a js module, removed custom xpcom interfaces
Diffstat (limited to 'components/interfaces/nsIFile.idl')
| -rw-r--r-- | components/interfaces/nsIFile.idl | 343 | 
1 files changed, 0 insertions, 343 deletions
| diff --git a/components/interfaces/nsIFile.idl b/components/interfaces/nsIFile.idl deleted file mode 100644 index cf97192..0000000 --- a/components/interfaces/nsIFile.idl +++ /dev/null @@ -1,343 +0,0 @@ -/* -*- 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 <dougt@netscape.com> - *   Christopher Blizzard <blizzard@mozilla.org> - *   Darin Fisher <darin@netscape.com> - * - * 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., 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 -%} | 
