📄 qdir_wce.cpp
字号:
/************************************************************************ Copyright (C) 2000-2005 Trolltech AS. All rights reserved.**** This file is part of the Qtopia Environment.** ** 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.** ** A copy of the GNU GPL license version 2 is included in this package as ** LICENSE.GPL.**** 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.**** In addition, as a special exception Trolltech gives permission to link** the code of this program with Qtopia applications copyrighted, developed** and distributed by Trolltech under the terms of the Qtopia Personal Use** License Agreement. You must comply with the GNU General Public License** in all respects for all of the code used other than the applications** licensed under the Qtopia Personal Use License Agreement. If you modify** this file, you may extend this exception to your version of the file,** but you are not obligated to do so. If you do not wish to do so, delete** this exception statement from your version.** ** See http://www.trolltech.com/gpl/ for GPL licensing information.**** Contact info@trolltech.com if any conditions of this licensing are** not clear to you.************************************************************************/#include "qplatformdefs.h"#include "qdir.h"#include "qdir_p.h"#include "qnamespace.h"#include "qfileinfo.h"#include "qfiledefs_p.h"#include "qregexp.h"#include "qstringlist.h"#include "qdeepcopy.h"#include "qlibrary.h"#ifdef QT_THREAD_SUPPORT# include <private/qmutexpool_p.h>#endif // QT_THREAD_SUPPORT#include <windows.h>#include <shlobj.h>#include <limits.h>static QString *theCWD = 0;void QDir::slashify( QString& n ){ if ( n.isNull() ) return; for ( int i=0; i<(int)n.length(); i++ ) { if ( n[i] == '\\' ) n[i] = '/'; }}QString QDir::homeDirPath(){ LPMALLOC pIMalloc = 0; HRESULT res = SHGetMalloc( &pIMalloc ); Q_ASSERT( pIMalloc ); typedef HRESULT (WINAPI *PtrSHGetSpecialFolderLocation)(HWND,int,LPITEMIDLIST*); static PtrSHGetSpecialFolderLocation ptrSHGetSpecialFolderLocation= 0; static bool shGSFLLookup = FALSE; if ( !shGSFLLookup ) { shGSFLLookup = TRUE; ptrSHGetSpecialFolderLocation = (PtrSHGetSpecialFolderLocation)QLibrary::resolve( "ceshell", "SHGetSpecialFolderLocation" ); } if ( ptrSHGetSpecialFolderLocation ) { LPITEMIDLIST il; if ( NOERROR != SHGetSpecialFolderLocation( 0, CSIDL_PERSONAL, &il ) ) return QString::null; TCHAR Path[ MAX_PATH ]; SHGetPathFromIDList( il, Path ); QString d = QString::fromUcs2( Path ); pIMalloc->Free( il ); slashify( d ); return d; } return QString::null;}QString QDir::canonicalPath() const{ QString aPath = dPath.copy(); if ( aPath.length() && aPath[0] == '.' ) aPath.prepend( QDir::currentDirPath() ); slashify( aPath ); QStringList aList = QStringList::split( '/', aPath ); QStringList::Iterator it = aList.begin(); uint elm = aList.size(), len = elm; // Create new canonical path at the end // of the current string list, by pushing // and popping to the back while ( len-- ) { if ( (*it) == "." ) { ++it; continue; } else if ( (*it) == ".." && aList.size() > elm ) { aList.pop_back(); } else { aList.push_back( (*it) ); } ++it; } // Remove all the original elements, so // we are left with only the canonical. len = elm; while ( len-- ) aList.pop_front(); aPath = aList.join( "/" ); return aPath.prepend( '/' );}bool QDir::mkdir( const QString &dirName, bool acceptAbsPath ) const{ return ::_wmkdir( (TCHAR*)filePath(dirName,acceptAbsPath).ucs2() ) == 0;}bool QDir::rmdir( const QString &dirName, bool acceptAbsPath ) const{ return ::_wrmdir( (TCHAR*)filePath(dirName,acceptAbsPath).ucs2() ) == 0;}bool QDir::isReadable() const{ return ::_waccess( (TCHAR*)dPath.ucs2(), R_OK ) == 0;}bool QDir::isRoot() const{ return dPath == "/" || dPath == "//" || (dPath[0].isLetter() && dPath.mid(1,dPath.length()) == ":/");}bool QDir::rename( const QString &oldName, const QString &newName, bool acceptAbsPaths ){ if ( oldName.isEmpty() || newName.isEmpty() ) {#if defined(QT_CHECK_NULL) qWarning( "QDir::rename: Empty or null file name" );#endif return FALSE; } QString fn1 = filePath( oldName, acceptAbsPaths ); QString fn2 = filePath( newName, acceptAbsPaths ); return ::_wrename( (TCHAR*)fn1.ucs2(), (TCHAR*)fn2.ucs2() ) == 0;}bool QDir::setCurrent( const QString &path ){#ifdef QT_THREAD_SUPPORT QMutexLocker locker( qt_global_mutexpool ? qt_global_mutexpool->get( &theCWD ) : 0 );#endif // QT_THREAD_SUPPORT DWORD res = GetFileAttributes( (TCHAR*)path.ucs2() ); if ( 0xFFFFFFFF == res ) return FALSE; if ( ! theCWD ) theCWD = new QString( QDeepCopy<QString>( path ) ); else *theCWD = QDeepCopy<QString>( path ); slashify( *theCWD ); return TRUE;}QString QDir::currentDirPath(){#ifdef QT_THREAD_SUPPORT QMutexLocker locker( qt_global_mutexpool ? qt_global_mutexpool->get( &theCWD ) : 0 );#endif // QT_THREAD_SUPPORT if ( ! theCWD ) setCurrent( "/" ); Q_ASSERT( theCWD != 0 ); return *theCWD;}QString QDir::rootDirPath(){ return QString( "/" );}bool QDir::isRelativePath( const QString &path ){ if ( path.isEmpty() ) return TRUE; return path[0] != '/' && path[0] != '\\';}bool QDir::readDirEntries( const QString &nameFilter, int filterSpec, int sortSpec ){ int i; QValueList<QRegExp> filters = qt_makeFilterList( nameFilter ); bool doDirs = (filterSpec & Dirs) != 0; bool doFiles = (filterSpec & Files) != 0; bool noSymLinks = (filterSpec & NoSymLinks) != 0; bool doReadable = (filterSpec & Readable) != 0; bool doWritable = (filterSpec & Writable) != 0; bool doExecable = (filterSpec & Executable) != 0; bool doHidden = (filterSpec & Hidden) != 0; // show hidden files if the user asks explicitly for e.g. .* if ( !doHidden && !nameFilter.isEmpty() && nameFilter[0] == '.' ) doHidden = TRUE; bool doModified = (filterSpec & Modified) != 0; bool doSystem = (filterSpec & System) != 0; bool first = TRUE; QString p = dPath.copy(); int plen = p.length(); HANDLE ff; WIN32_FIND_DATA finfo; QFileInfo fi;#undef IS_SUBDIR#undef IS_RDONLY#undef IS_ARCH#undef IS_HIDDEN#undef IS_SYSTEM#undef FF_ERROR#define IS_SUBDIR FILE_ATTRIBUTE_DIRECTORY#define IS_RDONLY FILE_ATTRIBUTE_READONLY#define IS_ARCH FILE_ATTRIBUTE_ARCHIVE#define IS_HIDDEN FILE_ATTRIBUTE_HIDDEN#define IS_SYSTEM FILE_ATTRIBUTE_SYSTEM#define FF_ERROR INVALID_HANDLE_VALUE if ( plen == 0 ) {#if defined(QT_CHECK_NULL) qWarning( "QDir::readDirEntries: No directory name specified" );#endif return FALSE; } if ( p.at(plen-1) != '/' && p.at(plen-1) != '\\' ) p += '/'; p += QString::fromLatin1("*.*"); ff = FindFirstFile( (TCHAR*)p.ucs2(), &finfo ); if ( !fList ) { fList = new QStringList; Q_CHECK_PTR( fList ); } else { fList->clear(); } if ( ff == FF_ERROR ) { // if it is a floppy disk drive, it might just not have a file on it if ( plen > 1 && p[1] == ':' && ( p[0]=='A' || p[0]=='a' || p[0]=='B' || p[0]=='b' ) ) { if ( !fiList ) { fiList = new QFileInfoList; Q_CHECK_PTR( fiList ); fiList->setAutoDelete( TRUE ); } else { fiList->clear(); } return TRUE; }#if defined(QT_CHECK_RANGE) qWarning( "QDir::readDirEntries: Cannot read the directory: %s (UTF8)", dPath.utf8().data() );#endif return FALSE; } if ( !fiList ) { fiList = new QFileInfoList; Q_CHECK_PTR( fiList ); fiList->setAutoDelete( TRUE ); } else { fiList->clear(); } for ( ;; ) { if ( first ) first = FALSE; else { if ( !FindNextFile(ff,&finfo) ) break; } int attrib = finfo.dwFileAttributes; bool isDir = (attrib & IS_SUBDIR) != 0; bool isFile = !isDir; bool isSymLink = FALSE; bool isReadable = TRUE; bool isWritable = (attrib & IS_RDONLY) == 0; bool isExecable = FALSE; bool isModified = (attrib & IS_ARCH) != 0; bool isHidden = (attrib & IS_HIDDEN) != 0; bool isSystem = (attrib & IS_SYSTEM) != 0; QString fname = QString::fromUcs2( (unsigned short *)finfo.cFileName ); if ( !qt_matchFilterList(filters, fname) && !(allDirs && isDir) ) continue; if ( (doDirs && isDir) || (doFiles && isFile) ) { QString name = fname; slashify(name); if ( doExecable ) { QString ext = name.right(4).lower(); if ( ext == ".exe" || ext == ".com" || ext == ".bat" || ext == ".pif" || ext == ".cmd" ) isExecable = TRUE; } if ( noSymLinks && isSymLink ) continue; if ( (filterSpec & RWEMask) != 0 ) if ( (doReadable && !isReadable) || (doWritable && !isWritable) || (doExecable && !isExecable) ) continue; if ( doModified && !isModified ) continue; if ( !doHidden && isHidden ) continue; if ( !doSystem && isSystem ) continue; fi.setFile( *this, name ); fiList->append( new QFileInfo( fi ) ); } } FindClose( ff );#undef IS_SUBDIR#undef IS_RDONLY#undef IS_ARCH#undef IS_HIDDEN#undef IS_SYSTEM#undef FF_ERROR // Sort... QDirSortItem* si= new QDirSortItem[fiList->count()]; QFileInfo* itm; i=0; for (itm = fiList->first(); itm; itm = fiList->next()) si[i++].item = itm; qt_cmp_si_sortSpec = sortSpec; qsort( si, i, sizeof(si[0]), qt_cmp_si ); // put them back in the list fiList->setAutoDelete( FALSE ); fiList->clear(); int j; for ( j=0; j<i; j++ ) { fiList->append( si[j].item ); fList->append( si[j].item->fileName() ); } delete [] si; fiList->setAutoDelete( TRUE ); if ( filterSpec == (FilterSpec)filtS && sortSpec == (SortSpec)sortS && nameFilter == nameFilt ) dirty = FALSE; else dirty = TRUE; return TRUE;}const QFileInfoList * QDir::drives(){ // at most one instance of QFileInfoList is leaked, and this variable // points to that list static QFileInfoList * knownMemoryLeak = 0; if ( !knownMemoryLeak ) {#ifdef QT_THREAD_SUPPORT QMutexLocker locker( qt_global_mutexpool ? qt_global_mutexpool->get( &knownMemoryLeak ) : 0 );#endif // QT_THREAD_SUPPORT if ( !knownMemoryLeak ) { knownMemoryLeak = new QFileInfoList; knownMemoryLeak->append( new QFileInfo( rootDirPath() ) ); } } return knownMemoryLeak;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -