gecko-dev/xpcom/io/nsLocalFileMac.h

110 lines
3.4 KiB
C
Raw Normal View History

1999-12-08 07:56:17 +00:00
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/*
* The contents of this file are subject to the Netscape 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/NPL/
*
* 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 Netscape are
* Copyright (C) 1998-1999 Netscape Communications Corporation. All
* Rights Reserved.
*
* Contributor(s):
* Steve Dagley <sdagley@netscape.com>
*/
#ifndef _nsLocalFileMAC_H_
#define _nsLocalFileMAC_H_
#include "nscore.h"
#include "nsError.h"
#include "nsString.h"
#include "nsCRT.h"
#include "nsIFile.h"
#include "nsILocalFile.h"
2000-01-24 21:28:28 +00:00
#include "nsILocalFileMac.h"
1999-12-08 07:56:17 +00:00
#include "nsIFactory.h"
#include "nsLocalFile.h"
#include <Files.h>
2000-01-24 21:28:28 +00:00
class NS_COM nsLocalFile : public nsILocalFile, public nsILocalFileMac
1999-12-08 07:56:17 +00:00
{
public:
NS_DEFINE_STATIC_CID_ACCESSOR(NS_LOCAL_FILE_CID)
nsLocalFile();
virtual ~nsLocalFile();
2000-01-24 21:28:28 +00:00
static NS_METHOD nsLocalFileConstructor(nsISupports* outer, const nsIID& aIID, void* *aInstancePtr);
1999-12-08 07:56:17 +00:00
// nsISupports interface
NS_DECL_ISUPPORTS
// nsIFile interface
NS_DECL_NSIFILE
// nsILocalFile interface
NS_DECL_NSILOCALFILE
2000-01-24 21:28:28 +00:00
NS_IMETHOD GetInitType(nsLocalFileMacInitType *type);
NS_IMETHOD InitWithFSSpec(const FSSpec *fileSpec);
NS_IMETHOD GetFSSpec(FSSpec *fileSpec);
NS_IMETHOD GetResolvedFSSpec(FSSpec *fileSpec);
NS_IMETHOD GetTargetFSSpec(FSSpec *fileSpec);
2000-01-24 21:28:28 +00:00
NS_IMETHOD SetAppendedPath(const char *aPath);
NS_IMETHOD GetAppendedPath(char * *aPath);
NS_IMETHOD GetFileTypeAndCreator(OSType *type, OSType *creator);
NS_IMETHOD SetFileTypeAndCreator(OSType type, OSType creator);
NS_IMETHOD GetFileSizeWithResFork(PRInt64 *aFileSize);
1999-12-08 07:56:17 +00:00
private:
// this is the flag which indicates if I can used cached information about the file
2000-01-24 21:28:28 +00:00
PRBool mStatDirty;
PRBool mLastResolveFlag;
1999-12-08 07:56:17 +00:00
2000-01-24 21:28:28 +00:00
// If we're inited with a path then we store it here
nsCString mWorkingPath;
1999-12-08 07:56:17 +00:00
2000-01-24 21:28:28 +00:00
// Any nodes added with AppendPath if we were initialized with an FSSpec are stored here
nsCString mAppendedPath;
1999-12-08 07:56:17 +00:00
// this will be the resolved path which will *NEVER* be returned to the user
2000-01-24 21:28:28 +00:00
nsCString mResolvedPath;
1999-12-08 07:56:17 +00:00
// The Mac data structure for a file system object
FSSpec mSpec; // This is the raw spec from InitWithPath or InitWithFSSpec
2000-01-24 21:28:28 +00:00
FSSpec mResolvedSpec; // This is the spec we've called ResolveAlias on
FSSpec mTargetSpec; // This is the spec we've called ResolveAlias on
Boolean mResolvedWasAlias; // mResolvedSpec was for an alias
Boolean mResolvedWasFolder; // mResolvedSpec was for a directory
2000-01-24 21:28:28 +00:00
// Is the mResolvedSpec member valid? Only after we resolve the mSpec or mWorkingPath
PRBool mHaveValidSpec;
// It's important we keep track of how we were initialized
nsLocalFileMacInitType mInitType;
1999-12-08 07:56:17 +00:00
void MakeDirty();
2000-01-24 21:28:28 +00:00
nsresult ResolveAndStat(PRBool resolveTerminal);
1999-12-08 07:56:17 +00:00
};
#endif