URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [tools/] [src/] [tools/] [Utils/] [win32/] [FileName.h] - Rev 778
Go to most recent revision | Compare with Previous | Blame | View Log
//####COPYRIGHTBEGIN#### // // ---------------------------------------------------------------------------- // Copyright (C) 1998, 1999, 2000 Red Hat, Inc. // // This program is part of the eCos host tools. // // This program is free software; you can redistribute it and/or modify it // under the terms of the GNU General Public License as published by the Free // Software Foundation; either version 2 of the License, or (at your option) // any later version. // // This program is distributed in the hope that it will be useful, but WITHOUT // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for // more details. // // You should have received a copy of the GNU General Public License along with // this program; if not, write to the Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // // ---------------------------------------------------------------------------- // //####COPYRIGHTEND#### //=========================================================================== //#####DESCRIPTIONBEGIN#### // // Author(s): sdf // Contact(s): sdf // Date: 1998/09/11 // Version: 0.01 // Purpose: Class to encapsulate filename operations (i.e. broadly on a file which probably do not involve opening // it). Importantly, the + and += operators performs filename segment addition, making sure that only one '\\' // comes between each piece. // Description: Interface of a the filename class // Requires: // Provides: // See also: // Known bugs: // Usage: // //####DESCRIPTIONEND#### // //=========================================================================== #ifndef _FILENAME_H #define _FILENAME_H #include <afxtempl.h> class CFileName; typedef CArray<CFileName,CFileName&> CFileNameArray; class CFileName : public CString { public: void ReplaceExtension (LPCTSTR pszNewExt); // previous directory is returned: static CFileName SetCurrentDirectory (LPCTSTR pszDir); const CString Root() const; const CString Extension() const; static CFileName GetTempPath(); bool IsAbsolute() const; static const TCHAR cSep; // The path separator ('\' on windows) // Standard ctors CFileName():CString(){} CFileName(const CFileName& stringSrc):CString(stringSrc){Normalize();} CFileName(const CString& stringSrc):CString(stringSrc){Normalize();} CFileName(TCHAR ch, int nRepeat = 1):CString(ch,nRepeat){Normalize();} CFileName(LPCSTR lpsz):CString(lpsz){Normalize();} CFileName(LPCWSTR lpsz):CString(lpsz){Normalize();} CFileName(LPCSTR lpch, int nLength):CString(lpch,nLength){Normalize();} CFileName(LPCWSTR lpch, int nLength):CString(lpch,nLength){Normalize();} CFileName(const unsigned char* psz):CString(psz){Normalize();} // Construct from path fragments CFileName(LPCTSTR,LPCTSTR); CFileName(LPCTSTR,LPCTSTR,LPCTSTR); CFileName(LPCTSTR,LPCTSTR,LPCTSTR,LPCTSTR); CFileName(LPCTSTR,LPCTSTR,LPCTSTR,LPCTSTR,LPCTSTR); // catenation operators: exactly one separator is placed between L and R const CFileName& operator+=(const CFileName& string); const CFileName& operator+=(TCHAR ch); #ifdef _UNICODE const CFileName& operator+=(char ch); #endif const CFileName& operator+=(LPCTSTR lpsz); friend CFileName AFXAPI operator+(const CFileName& string1,const CFileName& string2); friend CFileName AFXAPI operator+(const CFileName& string, TCHAR ch); friend CFileName AFXAPI operator+(TCHAR ch, const CFileName& string); #ifdef _UNICODE friend CFileName AFXAPI operator+(const CFileName& string, char ch); friend CFileName AFXAPI operator+(char ch, const CFileName& string); #endif friend CFileName AFXAPI operator+(const CFileName& string, LPCTSTR lpsz); friend CFileName AFXAPI operator+(LPCTSTR lpsz, const CFileName& string); // Textual append - no separator functionality const CFileName& Append (TCHAR ch); const CFileName& Append (LPCTSTR psz); // Utility functions const CFileName FullName() const; // full path name const CFileName NoSpaceName() const;// sans spaces const CFileName ShortName() const; // the type with ~s in it const CFileName Tail() const; // file name sans directory part const CFileName Head() const; // directory part const CFileName CygPath() const; // path mangled for CygWin static CFileName GetCurrentDirectory(); const CFileName& ExpandEnvironmentStrings(); static CFileName ExpandEnvironmentStrings(LPCTSTR psz); // Form path name relative to given parameter (if NULL, current directory) const CFileName& MakeRelative(LPCTSTR pszRelativeTo=0); static CFileName Relative(LPCTSTR psz,LPCTSTR pszRelativeTo=0); bool SameFile (const CFileName &strOther) const; bool SetFileAttributes (DWORD dwFileAttributes) const; DWORD Attributes() const { return ::GetFileAttributes(*this); } bool Exists () const {return 0xFFFFFFFF!=Attributes();} bool IsDir () const { DWORD a=Attributes(); return 0xFFFFFFFF!=a && (0!=(a&FILE_ATTRIBUTE_DIRECTORY));} bool IsFile () const { DWORD a=Attributes(); return 0xFFFFFFFF!=a && (0==(a&FILE_ATTRIBUTE_DIRECTORY));} bool IsReadOnly () const { DWORD a=Attributes(); return 0xFFFFFFFF!=a && (0!=(a&FILE_ATTRIBUTE_READONLY ));} FILETIME LastModificationTime() const; bool RecursivelyDelete(); bool CreateDirectory (bool bParentsToo=true,bool bFailIfAlreadyExists=false) const; static int FindFiles (LPCTSTR pszDir,CFileNameArray &ar,LPCTSTR pszPattern=_T("*.*"),bool bRecurse=true,DWORD dwExclude=FILE_ATTRIBUTE_DIRECTORY|FILE_ATTRIBUTE_HIDDEN); protected: // Helpers for Relative(): LPCTSTR *Chop (); static CFileName Drive(LPCTSTR psz); // Remove trailing '/' (helper for ctors) void Normalize(); // Implementating catenation functionality: void ConcatInPlace(int nSrcLen, LPCTSTR lpszSrcData); void ConcatCopy(int nSrc1Len, LPCTSTR lpszSrc1Data,int nSrc2Len, LPCTSTR lpszSrc2Data); }; class CSaveExcursion { const CFileName m_strPrevDir; public: CSaveExcursion(LPCTSTR pszDir) : m_strPrevDir(CFileName::SetCurrentDirectory(pszDir)) {} ~CSaveExcursion() { ::SetCurrentDirectory(m_strPrevDir); } bool Ok() const { return !m_strPrevDir.IsEmpty(); } }; #endif
Go to most recent revision | Compare with Previous | Blame | View Log