|
/*
CBinFile.h
Classe base per files binari (SDK).
Luca Piergentili, 31/08/98
lpiergentili@yahoo.com
http://www.geocities.com/lpiergentili/
*/
#ifndef _CBINFILE_H
#define _CBINFILE_H 1
#include "window.h"
// access type
#define GENERIC_QUERY 0 // Specifies device query access to the object. An application can query device attributes without accessing the device.
//GENERIC_READ Specifies read access to the object. Data can be read from the file and the file pointer can be moved. Combine with GENERIC_WRITE for read-write access.
//GENERIC_WRITE Specifies write access to the object. Data can be written to the file and the file pointer can be moved. Combine with GENERIC_READ for read-write access.
// share mode
//FILE_SHARE_DELETE Windows NT only: Subsequent open operations on the object will succeed only if delete access is requested.
//FILE_SHARE_READ Subsequent open operations on the object will succeed only if read access is requested.
//FILE_SHARE_WRITE Subsequent open operations on the object will succeed only if write access is requested.
// W95
#define FILE_SHARE (FILE_SHARE_READ|FILE_SHARE_WRITE)
// WNT
//#define FILE_SHARE (FILE_SHARE_DELETE|FILE_SHARE_READ|FILE_SHARE_WRITE)
#define FILE_EXCLUSIVE 0
// create mode
//CREATE_NEW Creates a new file. The function fails if the specified file already exists.
//CREATE_ALWAYS Creates a new file. The function overwrites the file if it exists.
//OPEN_EXISTING Opens the file. The function fails if the file does not exist. See the Remarks section for a discussion of why you should use the OPEN_EXISTING flag if you are using the CreateFile function for devices, including the console.
//OPEN_ALWAYS Opens the file, if it exists. If the file does not exist, the function creates the file as if dwCreationDistribution were CREATE_NEW.
//TRUNCATE_EXISTING Opens the file. Once opened, the file is truncated so that its size is zero bytes. The calling process must open the file with at least GENERIC_WRITE access. The function fails if the file does not exist.
// attribute
//FILE_ATTRIBUTE_ARCHIVE The file should be archived. Applications use this attribute to mark files for backup or removal.
//FILE_ATTRIBUTE_COMPRESSED The file or directory is compressed. For a file, this means that all of the data in the file is compressed. For a directory, this means that compression is the default for newly created files and subdirectories.
//FILE_ATTRIBUTE_HIDDEN The file is hidden. It is not to be included in an ordinary directory listing.
//FILE_ATTRIBUTE_NORMAL The file has no other attributes set. This attribute is valid only if used alone.
//FILE_ATTRIBUTE_OFFLINE The data of the file is not immediately available. Indicates that the file data has been physically moved to offline storage.
//FILE_ATTRIBUTE_READONLY The file is read only. Applications can read the file but cannot write to it or delete it.
//FILE_ATTRIBUTE_SYSTEM The file is part of or is used exclusively by the operating system.
//FILE_ATTRIBUTE_TEMPORARY The file is being used for temporary storage. File systems attempt to keep all of the data in memory for quicker access rather than flushing the data back to mass storage. A temporary file should be deleted by the application as soon as it is no longer needed.
// ofs:pos (lseek)
#define FILE_EOF ((DWORD)-1)
//FILE_BEGIN The starting point is zero or the beginning of the file. If FILE_BEGIN is specified, DistanceToMove is interpreted as an unsigned location for the new file pointer.
//FILE_CURRENT The current value of the file pointer is the starting point.
//FILE_END The current end-of-file position is the starting point.
#define MAX_ERR_STRING 256
class CBinFile
{
public:
CBinFile();
virtual ~CBinFile();
BOOL Open (LPCSTR lpcszFileName,BOOL bCreateIfNotExist = TRUE,DWORD dwAccessMode = GENERIC_READ|GENERIC_WRITE,DWORD dwShareMode = FILE_SHARE);
BOOL Create (LPCSTR lpcszFileName,DWORD dwAccessMode = GENERIC_READ|GENERIC_WRITE,DWORD dwShareMode = FILE_SHARE,DWORD dwAttribute = FILE_ATTRIBUTE_NORMAL);
DWORD Read (LPVOID lpBuffer,DWORD dwToRead);
DWORD Write (LPCVOID lpcBuffer,DWORD dwToWrite);
DWORD Seek (LONG lOffset,DWORD dwOrigin);
inline DWORD GetFileOffset (void) {return(CBinFile::Seek(0L,0L));}
inline DWORD GetFileSize (void) {return(m_hHandle!=INVALID_HANDLE_VALUE ? ::GetFileSize(m_hHandle,NULL) : 0L);}
BOOL Close (void);
inline BOOL IsOpen (void) {return((m_hHandle!=INVALID_HANDLE_VALUE));}
inline DWORD GetLastErrorCode (void) {return(m_dwError);}
inline LPCSTR GetLastErrorString (void) {return(m_szError);}
inline void ShowErrors (BOOL bFlag) {m_bShowErrors = bFlag;}
protected:
void SetLastErrorCode (DWORD);
BOOL m_bShowErrors;
HANDLE m_hHandle;
DWORD m_dwError;
char m_szFileName[_MAX_PATH+1];
char m_szError[MAX_ERR_STRING+1];
};
#endif // _CBINFILE
|
By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.
If a file you wish to view isn't highlighted, and is a text file (not binary), please
let us know and we'll add colourisation support for it.
This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.
A list of licenses authors might use can be found here
I like C and C++, Acid Jazz, James Brown, gli Spaghetti Aglio e Olio, alla Bolognesa, alla Puttanesca e le Fettuccine alla Matriciana ('Maccaroni' over the world). Of course I like beautiful big tits girls too, my little car, Frank Zappa, the art of Zen, italian coffee and much more...