/usr/include/sipxtapi/os/OsFileIteratorBase.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 | //
// Copyright (C) 2005 SIPez LLC.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// Copyright (C) 2004-2006 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _OsFileIteratorBase_h_
#define _OsFileIteratorBase_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include <os/OsDefs.h>
#include <os/OsStatus.h>
#include <os/OsPathBase.h>
#include <utl/UtlRegex.h>
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
class OsFileInfoBase;
class OsFileBase;
//:Abstraction class to iterate through files and/or directories
class OsFileIteratorBase
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
enum OsFileType
{
ANY_FILE,
DIRECTORIES,
FILES
};
#ifdef _WIN32
enum { INVALID_HANDLE = -1 };
#else
enum { INVALID_HANDLE = 0 };
#endif
//: type specified for FindFirst
//!enumcode: ANY_FILE - Directories and Files
//!enumcode: DIRECTORY - Search for directories only
//!enumcode: FILE - Search for files only
/* ============================ CREATORS ================================== */
OsFileIteratorBase();
OsFileIteratorBase(const OsPathBase& rPathName);
virtual ~OsFileIteratorBase();
//:Destructor
/* ============================ MANIPULATORS ============================== */
/* ============================ ACCESSORS ================================= */
virtual OsStatus findFirst(OsPathBase& rEntry, const char* filterExp = ".*",
OsFileType fileType = ANY_FILE);
//: Searches a directory specified by rEntry for all entries matching
//: the (unanchored) regexp filterExp and also of type fileType.
//: Returns the full path name of the found entries.
//: filterExp is unanchored; it need only match a substring of the
//: file name. To force it to match the entire file name, use "^...$".
//: On Unix-like systems the "." and ".." entries may be returned.
virtual OsStatus findNext(OsPathBase& rEntry);
//: Finds the next entry matching the search criteria.
//: Use FindFirst before calling this function.
/* ============================ INQUIRY =================================== */
int getFileCount() {return mFileCount;}
//: Returns total files enumerated thus far.
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
OsPathBase mUserSpecifiedPath;
//: What the user passed in as path to search
OsPathBase mFullSearchSpec;
//: What is searched against the filesystem
RegEx* mFilterExp;
//: The regular expression that the user searched for
long mSearchHandle;
// release memory that allocated for mFilterExp
//
// Morerover, OsFileIteratorBase's Subclass needs override this
// function for releasing mSearchHandle.
virtual void Release();
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
virtual OsStatus getNextEntryName(UtlString &rName, OsFileType &rFileType);
//: Platform dependant call for getting entry
virtual OsStatus getFirstEntryName(UtlString &rName, OsFileType &rFileType);
//: Platform dependant call for getting entry
OsFileType mMatchAttrib;
//: Attributes for file matching
long mFileCount;
//: How many file did this class find
};
/* ============================ INLINE METHODS ============================ */
#endif // _OsFileIteratorBase_h_
|