mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0024259: Clean up OSD_File implementation
Field myFileChannel removed from OSD_FileNode and introduced to OSD_File as Linux-only along with Windows-only myFileHandle. Implementation of OSD_File cleaned from redundant type casts; some missing type cases added. File mode passed to fdopen() corrected in read-write case ("rw" replaced by "w+"). Method OSD_File::Size() now returns Standard_Size to be able to return correct value for large files (on 64-bit platforms only).
This commit is contained in:
parent
8fa64b522f
commit
6ff736d802
@ -186,7 +186,7 @@ class File from OSD inherits FileNode
|
||||
---Level: Public
|
||||
raises ProgramError is static;
|
||||
|
||||
Size (me: out) returns Integer
|
||||
Size (me: out) returns Size
|
||||
---Purpose: Returns actual number of bytes of <me>.
|
||||
---Level: Public
|
||||
raises ProgramError is static;
|
||||
@ -232,9 +232,8 @@ class File from OSD inherits FileNode
|
||||
myMode : OpenMode;
|
||||
myIO : Integer is protected; -- Stores peculiar I/O informations
|
||||
myFILE : Address is protected;
|
||||
myBuffer : CString ;
|
||||
myCurrPtr : CString ;
|
||||
myEndPtr : CString ;
|
||||
myFileChannel : Integer is protected; -- file descriptor, Unix/Linux only
|
||||
myFileHandle : Address is protected; -- file handle, Windows only
|
||||
end File from OSD;
|
||||
|
||||
|
||||
|
@ -24,8 +24,7 @@
|
||||
// UNIX Part
|
||||
//------------------------------------------------------------------------
|
||||
|
||||
|
||||
#ifndef WNT
|
||||
#ifndef _WIN32
|
||||
|
||||
#include <Standard_ProgramError.hxx>
|
||||
#include <OSD_OSDError.hxx>
|
||||
@ -67,29 +66,34 @@ const OSD_WhoAmI Iam = OSD_WFile;
|
||||
// Create an empty file object
|
||||
// ---------------------------------------------------------------------
|
||||
|
||||
OSD_File::OSD_File():OSD_FileNode() {
|
||||
OSD_File::OSD_File():OSD_FileNode()
|
||||
{
|
||||
ImperativeFlag = Standard_False;
|
||||
myLock = OSD_NoLock;
|
||||
myIO = 0;
|
||||
myMode = OSD_ReadWrite;
|
||||
myFileChannel = -1;
|
||||
myFILE = (Standard_Address) NULL;
|
||||
myFileChannel = -1;
|
||||
myFileHandle = 0;
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
// Create and initialize a file object
|
||||
// ---------------------------------------------------------------------
|
||||
|
||||
OSD_File::OSD_File(const OSD_Path& Name):OSD_FileNode(Name){
|
||||
|
||||
OSD_File::OSD_File(const OSD_Path& Name):OSD_FileNode(Name)
|
||||
{
|
||||
ImperativeFlag = Standard_False;
|
||||
myLock = OSD_NoLock;
|
||||
myIO = 0;
|
||||
myMode = OSD_ReadWrite;
|
||||
myFileChannel = -1;
|
||||
myFILE = (Standard_Address) NULL;
|
||||
myFileChannel = -1;
|
||||
myFileHandle = 0;
|
||||
}
|
||||
|
||||
// protect against occasional use of myFileHande in Linux code
|
||||
#define myFileHandle myFileHandle_is_only_for_Windows
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
// Build a file if it doesn't exist or create again if it already exists
|
||||
@ -113,27 +117,27 @@ void OSD_File::Build(const OSD_OpenMode Mode,
|
||||
|
||||
internal_prot = Protect.Internal();
|
||||
|
||||
char CMode[5];
|
||||
const char* CMode = "r";
|
||||
|
||||
switch (Mode){
|
||||
case OSD_ReadOnly:
|
||||
internal_mode |= O_RDONLY;
|
||||
strcpy (CMode,"r");
|
||||
CMode = "r";
|
||||
break;
|
||||
case OSD_WriteOnly:
|
||||
internal_mode |= O_WRONLY;
|
||||
strcpy (CMode,"w");
|
||||
CMode = "w";
|
||||
break;
|
||||
case OSD_ReadWrite:
|
||||
internal_mode |= O_RDWR;
|
||||
strcpy (CMode,"rw");
|
||||
CMode = "w+";
|
||||
break;
|
||||
}
|
||||
|
||||
myPath.SystemName( aBuffer );
|
||||
myFileChannel = open (aBuffer.ToCString(),(int) internal_mode,(int) internal_prot);
|
||||
myFileChannel = open (aBuffer.ToCString(), internal_mode, internal_prot);
|
||||
if (myFileChannel >= 0) {
|
||||
myFILE = fdopen (myFileChannel,(const char*) CMode);
|
||||
myFILE = fdopen (myFileChannel, CMode);
|
||||
}
|
||||
else
|
||||
/* Handle OPEN errors */
|
||||
@ -166,23 +170,21 @@ void OSD_File::Append(const OSD_OpenMode Mode,
|
||||
Standard_ProgramError::Raise("OSD_File::Append : file is already open");
|
||||
|
||||
internal_prot = Protect.Internal();
|
||||
|
||||
|
||||
myMode = Mode;
|
||||
char CMode[5];
|
||||
const char* CMode = "r";
|
||||
|
||||
switch (Mode){
|
||||
case OSD_ReadOnly:
|
||||
internal_mode |= O_RDONLY;
|
||||
strcpy (CMode,"r");
|
||||
CMode = "r";
|
||||
break;
|
||||
case OSD_WriteOnly:
|
||||
internal_mode |= O_WRONLY;
|
||||
strcpy (CMode,"a");
|
||||
CMode = "a";
|
||||
break;
|
||||
case OSD_ReadWrite:
|
||||
internal_mode |= O_RDWR;
|
||||
strcpy (CMode,"a");
|
||||
CMode = "a+";
|
||||
break;
|
||||
}
|
||||
|
||||
@ -191,9 +193,9 @@ void OSD_File::Append(const OSD_OpenMode Mode,
|
||||
if (!Exists()) internal_mode |= O_CREAT;
|
||||
|
||||
myPath.SystemName ( aBuffer );
|
||||
myFileChannel = open (aBuffer.ToCString(),(int) internal_mode,(int) internal_prot);
|
||||
myFileChannel = open (aBuffer.ToCString(), internal_mode, internal_prot);
|
||||
if (myFileChannel >= 0)
|
||||
myFILE = fdopen (myFileChannel,(const char*) CMode);
|
||||
myFILE = fdopen (myFileChannel, CMode);
|
||||
else
|
||||
/* Handle OPEN errors */
|
||||
|
||||
@ -222,30 +224,28 @@ void OSD_File::Open(const OSD_OpenMode Mode,
|
||||
Standard_ProgramError::Raise("OSD_File::Open : file is already open");
|
||||
|
||||
internal_prot = Protect.Internal();
|
||||
|
||||
|
||||
myMode = Mode;
|
||||
char CMode[5];
|
||||
const char* CMode = "r";
|
||||
|
||||
switch (Mode){
|
||||
case OSD_ReadOnly:
|
||||
internal_mode |= O_RDONLY;
|
||||
strcpy (CMode,"r");
|
||||
CMode = "r";
|
||||
break;
|
||||
case OSD_WriteOnly:
|
||||
internal_mode |= O_WRONLY;
|
||||
strcpy (CMode,"w");
|
||||
CMode = "w";
|
||||
break;
|
||||
case OSD_ReadWrite:
|
||||
internal_mode |= O_RDWR;
|
||||
strcpy (CMode,"rw");
|
||||
CMode = "w+";
|
||||
break;
|
||||
}
|
||||
|
||||
myPath.SystemName ( aBuffer );
|
||||
myFileChannel = open (aBuffer.ToCString(),(int) internal_mode,(int) internal_prot);
|
||||
myFileChannel = open (aBuffer.ToCString(), internal_mode, internal_prot);
|
||||
if (myFileChannel >= 0)
|
||||
myFILE = fdopen (myFileChannel,(const char*) CMode);
|
||||
myFILE = fdopen (myFileChannel, CMode);
|
||||
else
|
||||
/* Handle OPEN errors */
|
||||
|
||||
@ -264,7 +264,7 @@ OSD_File OSD_File::BuildTemporary(){
|
||||
int dummy;
|
||||
|
||||
fic = tmpfile();
|
||||
dummy = open("dummy", O_RDWR | O_CREAT); // Open a summy file
|
||||
dummy = open("dummy", O_RDWR | O_CREAT); // Open a dummy file
|
||||
result.myFileChannel = dummy - 1; // This is file channel of "fic" +1
|
||||
close(dummy); // Close dummy file
|
||||
unlink("dummy"); // Removes dummy file
|
||||
@ -319,7 +319,7 @@ void OSD_File::Read(TCollection_AsciiString& Buffer,
|
||||
TCollection_AsciiString transfert(Nbyte,' ');
|
||||
readbuf = (Standard_PCharacter)transfert.ToCString();
|
||||
|
||||
status = read( (int)myFileChannel, readbuf, Nbyte);
|
||||
status = read (myFileChannel, readbuf, Nbyte);
|
||||
//
|
||||
Buffer = transfert; // Copy transfert to Buffer
|
||||
|
||||
@ -372,7 +372,7 @@ void OSD_File::ReadLine(TCollection_AsciiString& Buffer,
|
||||
}
|
||||
}
|
||||
else {
|
||||
NByteRead = strlen(abuffer);
|
||||
NByteRead = (Standard_Integer)strlen(abuffer);
|
||||
Buffer.SetValue(1,abuffer); // Copy transfert to Buffer
|
||||
Buffer.Trunc(NByteRead);
|
||||
}
|
||||
@ -427,12 +427,12 @@ void OSD_File::Read( Standard_Address& Buffer,
|
||||
if (Buffer == NULL)
|
||||
Standard_ProgramError::Raise("OSD_File::Read : Buffer is null");
|
||||
|
||||
status = read( (int)myFileChannel, (char*) Buffer, Nbyte);
|
||||
status = read (myFileChannel, (char*) Buffer, Nbyte);
|
||||
|
||||
if (status == -1) myError.SetValue (errno, Iam, "Read");
|
||||
else{
|
||||
if ( status < Nbyte ) myIO = EOF;
|
||||
Readbyte = (Standard_Integer) status;
|
||||
Readbyte = status;
|
||||
}
|
||||
}
|
||||
|
||||
@ -461,7 +461,7 @@ void OSD_File::Write(const TCollection_AsciiString &Buffer,
|
||||
|
||||
writebuf = Buffer.ToCString();
|
||||
|
||||
status = write( (int)myFileChannel, writebuf, Nbyte);
|
||||
status = write (myFileChannel, writebuf, Nbyte);
|
||||
|
||||
if ( status == -1) myError.SetValue (errno, Iam, "Write");
|
||||
else
|
||||
@ -486,7 +486,7 @@ void OSD_File::Write(const Standard_Address Buffer,
|
||||
if (Nbyte <= 0)
|
||||
Standard_ProgramError::Raise("OSD_File::Write : Nbyte is null");
|
||||
|
||||
status = write( (int)myFileChannel, (const char *)Buffer, Nbyte);
|
||||
status = write (myFileChannel, (const char *)Buffer, Nbyte);
|
||||
|
||||
if ( status == -1) myError.SetValue (errno, Iam, "Write");
|
||||
else
|
||||
@ -501,7 +501,7 @@ void OSD_File::Write(const Standard_Address Buffer,
|
||||
|
||||
void OSD_File::Seek(const Standard_Integer Offset,
|
||||
const OSD_FromWhere Whence){
|
||||
int status,where=0;
|
||||
int iwhere=0;
|
||||
|
||||
if (myFileChannel == -1)
|
||||
Standard_ProgramError::Raise("OSD_File::Seek : file is not open");
|
||||
@ -510,19 +510,19 @@ void OSD_File::Seek(const Standard_Integer Offset,
|
||||
|
||||
switch (Whence){
|
||||
case OSD_FromBeginning :
|
||||
where = SEEK_SET;
|
||||
iwhere = SEEK_SET;
|
||||
break;
|
||||
case OSD_FromHere:
|
||||
where = SEEK_CUR;
|
||||
iwhere = SEEK_CUR;
|
||||
break;
|
||||
case OSD_FromEnd:
|
||||
where = SEEK_END;
|
||||
iwhere = SEEK_END;
|
||||
break;
|
||||
default :
|
||||
myError.SetValue (EINVAL, Iam, "Seek");
|
||||
}
|
||||
status = (int) lseek( (int)myFileChannel, Offset, where );
|
||||
|
||||
off_t status = lseek (myFileChannel, Offset, iwhere);
|
||||
if (status == -1) myError.SetValue (errno, Iam, "Seek");
|
||||
}
|
||||
|
||||
@ -541,13 +541,14 @@ void OSD_File::Close(){
|
||||
|
||||
if (Failed()) Perror();
|
||||
|
||||
status = close ( (int) myFileChannel );
|
||||
// note: it probably should be single call to fclose()...
|
||||
status = close (myFileChannel);
|
||||
|
||||
if (status == -1) myError.SetValue (errno, Iam, "Close");
|
||||
myFileChannel = -1;
|
||||
if ( myFILE != NULL ) {
|
||||
status = fclose ( (FILE*) myFILE );
|
||||
myFILE = (Standard_Address) NULL;
|
||||
myFILE = NULL;
|
||||
}
|
||||
myIO = 0;
|
||||
}
|
||||
@ -602,7 +603,7 @@ int status;
|
||||
return;
|
||||
}
|
||||
|
||||
if (fstat((int)myFileChannel, &buf) == -1) {
|
||||
if (fstat (myFileChannel, &buf) == -1) {
|
||||
myError.SetValue (errno, Iam, "SetLock");
|
||||
return;
|
||||
}
|
||||
@ -630,12 +631,12 @@ int status;
|
||||
key.l_start = 0;
|
||||
key.l_len = 0;
|
||||
|
||||
status = fcntl( (int) myFileChannel ,F_SETLKW,(long) &key);
|
||||
status = fcntl (myFileChannel, F_SETLKW, &key);
|
||||
if (status == -1) myError.SetValue (errno, Iam, "SetLock");
|
||||
else myLock = Lock;
|
||||
|
||||
if (Lock == OSD_ExclusiveLock){
|
||||
fstat( (int) myFileChannel ,&buf);
|
||||
fstat (myFileChannel, &buf);
|
||||
TCollection_AsciiString aBuffer;
|
||||
myPath.SystemName ( aBuffer );
|
||||
chmod( aBuffer.ToCString() ,buf.st_mode | S_ISGID);
|
||||
@ -654,7 +655,7 @@ int status;
|
||||
default : myError.SetValue (EINVAL, Iam, "SetLock");
|
||||
}
|
||||
|
||||
status = flock((int)myFileChannel,lock);
|
||||
status = flock (myFileChannel, lock);
|
||||
if (status == -1) myError.SetValue (errno, Iam, "SetLock");
|
||||
else myLock = Lock;
|
||||
#endif // SysV
|
||||
@ -689,18 +690,18 @@ int status;
|
||||
struct flock key;
|
||||
|
||||
if (ImperativeFlag){
|
||||
fstat((int)myFileChannel,&buf);
|
||||
fstat (myFileChannel, &buf);
|
||||
TCollection_AsciiString aBuffer;
|
||||
myPath.SystemName ( aBuffer );
|
||||
chmod(aBuffer.ToCString(),buf.st_mode & ~S_ISGID);
|
||||
ImperativeFlag = Standard_False;
|
||||
}
|
||||
key.l_type = F_UNLCK;
|
||||
status = fcntl((int)myFileChannel,F_SETLK,(long) &key);
|
||||
status = fcntl (myFileChannel, F_SETLK, &key);
|
||||
if (status == -1) myError.SetValue (errno, Iam, "UnSetLock");
|
||||
#else
|
||||
|
||||
status = flock((int)myFileChannel,LOCK_UN);
|
||||
status = flock (myFileChannel, LOCK_UN);
|
||||
if (status == -1) myError.SetValue (errno, Iam, "UnSetLock");
|
||||
#endif
|
||||
#endif // POSIX
|
||||
@ -727,7 +728,7 @@ OSD_LockType OSD_File::GetLock(){
|
||||
// Return size of a file
|
||||
// --------------------------------------------------------------------------
|
||||
|
||||
Standard_Integer OSD_File::Size(){
|
||||
Standard_Size OSD_File::Size(){
|
||||
struct stat buffer;
|
||||
int status;
|
||||
|
||||
@ -739,10 +740,10 @@ Standard_Integer OSD_File::Size(){
|
||||
status = stat( aBuffer.ToCString() ,&buffer );
|
||||
if (status == -1) {
|
||||
myError.SetValue (errno, Iam, "Size");
|
||||
return (-1);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return ( buffer.st_size );
|
||||
return (Standard_Size)buffer.st_size;
|
||||
}
|
||||
|
||||
|
||||
@ -828,7 +829,7 @@ Standard_Boolean OSD_File::IsExecutable()
|
||||
return Standard_True;
|
||||
}
|
||||
|
||||
#else //WNT
|
||||
#else /* _WIN32 */
|
||||
|
||||
//------------------------------------------------------------------------
|
||||
//------------------- Windows NT sources for OSD_File -------------------
|
||||
@ -862,7 +863,7 @@ Standard_Boolean OSD_File::IsExecutable()
|
||||
#define ACE_HEADER_SIZE ( sizeof ( ACCESS_ALLOWED_ACE ) - sizeof ( DWORD ) )
|
||||
|
||||
#define RAISE( arg ) Standard_ProgramError :: Raise ( ( arg ) )
|
||||
#define TEST_RAISE( arg ) _test_raise ( myFileChannel, ( arg ) )
|
||||
#define TEST_RAISE( arg ) _test_raise ( myFileHandle, ( arg ) )
|
||||
|
||||
#define OPEN_NEW 0
|
||||
#define OPEN_OLD 1
|
||||
@ -875,7 +876,7 @@ BOOL __fastcall _osd_wnt_sd_to_protection (
|
||||
);
|
||||
BOOL __fastcall _osd_print (const Standard_PCharacter, Standard_CString );
|
||||
|
||||
static void __fastcall _test_raise ( Standard_Integer, Standard_CString );
|
||||
static void __fastcall _test_raise ( HANDLE, Standard_CString );
|
||||
static DWORDLONG __fastcall _get_line ( Standard_PCharacter&, DWORD );
|
||||
static int __fastcall _get_buffer ( HANDLE, Standard_PCharacter&, DWORD, BOOL, BOOL );
|
||||
static DWORD __fastcall _get_access_mask ( OSD_SingleProtection );
|
||||
@ -887,33 +888,38 @@ static OSD_SingleProtection __fastcall _get_protection_dir ( DWORD );
|
||||
|
||||
typedef OSD_SingleProtection ( __fastcall *GET_PROT_FUNC ) ( DWORD );
|
||||
|
||||
Standard_Integer __fastcall _get_file_type ( Standard_CString, Standard_Integer );
|
||||
Standard_Integer __fastcall _get_file_type ( Standard_CString, HANDLE );
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
// Create an empty file object
|
||||
// ---------------------------------------------------------------------
|
||||
|
||||
OSD_File :: OSD_File () {
|
||||
|
||||
OSD_File :: OSD_File ()
|
||||
{
|
||||
ImperativeFlag = Standard_False;
|
||||
myLock = OSD_NoLock;
|
||||
myIO = 0;
|
||||
|
||||
myFileChannel = -1;
|
||||
myFileHandle = INVALID_HANDLE_VALUE;
|
||||
} // end constructor ( 1 )
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
// Create and initialize a file object
|
||||
// ---------------------------------------------------------------------
|
||||
|
||||
OSD_File :: OSD_File ( const OSD_Path& Name ) : OSD_FileNode ( Name ) {
|
||||
|
||||
OSD_File :: OSD_File ( const OSD_Path& Name ) : OSD_FileNode ( Name )
|
||||
{
|
||||
ImperativeFlag = Standard_False;
|
||||
myLock = OSD_NoLock;
|
||||
myIO = 0;
|
||||
myPath = Name;
|
||||
|
||||
myFileChannel = -1;
|
||||
myFileHandle = INVALID_HANDLE_VALUE;
|
||||
} // end constructor ( 2 )
|
||||
|
||||
// protect against occasional use of myFileHande in Windows code
|
||||
#define myFileChannel myFileChannel_is_only_for_Linux
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
// Build a file if it doesn't exist or create again if it already exists
|
||||
// ---------------------------------------------------------------------
|
||||
@ -928,7 +934,7 @@ void OSD_File :: Build (
|
||||
Standard_ProgramError::Raise("OSD_File::Read : it is a directory");
|
||||
}
|
||||
|
||||
if ( ( HANDLE )myFileChannel != INVALID_HANDLE_VALUE )
|
||||
if (myFileHandle != INVALID_HANDLE_VALUE)
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Build (): incorrect call - file already opened" ) );
|
||||
|
||||
@ -939,9 +945,9 @@ void OSD_File :: Build (
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Build (): incorrent call - no filename given" ) );
|
||||
|
||||
myFileChannel = ( Standard_Integer )_open_file ( fName.ToCString (), Mode, OPEN_NEW );
|
||||
myFileHandle = _open_file ( fName.ToCString (), Mode, OPEN_NEW );
|
||||
|
||||
if ( ( HANDLE )myFileChannel == INVALID_HANDLE_VALUE )
|
||||
if (myFileHandle == INVALID_HANDLE_VALUE)
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
@ -966,7 +972,7 @@ void OSD_File :: Open (const OSD_OpenMode Mode, const OSD_Protection& /*Protect*
|
||||
TCollection_AsciiString fName;
|
||||
|
||||
|
||||
if ( ( HANDLE )myFileChannel != INVALID_HANDLE_VALUE )
|
||||
if (myFileHandle != INVALID_HANDLE_VALUE)
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Open (): incorrect call - file already opened" ) );
|
||||
|
||||
@ -977,15 +983,15 @@ void OSD_File :: Open (const OSD_OpenMode Mode, const OSD_Protection& /*Protect*
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Open (): incorrent call - no filename given" ) );
|
||||
|
||||
myFileChannel = ( Standard_Integer )_open_file ( fName.ToCString (), Mode, OPEN_OLD );
|
||||
myFileHandle = _open_file ( fName.ToCString (), Mode, OPEN_OLD );
|
||||
|
||||
if ( ( HANDLE )myFileChannel == INVALID_HANDLE_VALUE ) {
|
||||
if (myFileHandle == INVALID_HANDLE_VALUE) {
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
}
|
||||
else
|
||||
{
|
||||
myIO |= _get_file_type ( fName.ToCString (), myFileChannel );
|
||||
myIO |= _get_file_type ( fName.ToCString (), myFileHandle );
|
||||
}
|
||||
} // end OSD_File :: Open
|
||||
|
||||
@ -1000,7 +1006,7 @@ void OSD_File :: Append (
|
||||
BOOL fNew = FALSE;
|
||||
TCollection_AsciiString fName;
|
||||
|
||||
if ( ( HANDLE )myFileChannel != INVALID_HANDLE_VALUE )
|
||||
if (myFileHandle != INVALID_HANDLE_VALUE)
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Append (): incorrect call - file already opened" ) );
|
||||
|
||||
@ -1011,9 +1017,9 @@ void OSD_File :: Append (
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Append (): incorrent call - no filename given" ) );
|
||||
|
||||
myFileChannel = ( Standard_Integer )_open_file ( fName.ToCString (), Mode, OPEN_APPEND, &fNew );
|
||||
myFileHandle = _open_file ( fName.ToCString (), Mode, OPEN_APPEND, &fNew );
|
||||
|
||||
if ( ( HANDLE )myFileChannel == INVALID_HANDLE_VALUE )
|
||||
if (myFileHandle == INVALID_HANDLE_VALUE)
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
@ -1021,7 +1027,7 @@ void OSD_File :: Append (
|
||||
|
||||
if ( !fNew ) {
|
||||
|
||||
myIO |= _get_file_type ( fName.ToCString (), myFileChannel );
|
||||
myIO |= _get_file_type ( fName.ToCString (), myFileHandle );
|
||||
Seek ( 0, OSD_FromEnd );
|
||||
|
||||
} else {
|
||||
@ -1072,14 +1078,10 @@ void OSD_File :: Read (
|
||||
|
||||
} // end OSD_File :: Read
|
||||
|
||||
#define PRO13471
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
// Read a line from a file
|
||||
// ---------------------------------------------------------------------
|
||||
|
||||
#ifdef PRO13471
|
||||
|
||||
// Modified so that we have <nl> at end of line if we have read <nl> or <cr>
|
||||
// in the file.
|
||||
// by LD 17 dec 98 for B4.4
|
||||
@ -1117,10 +1119,7 @@ void OSD_File :: ReadLine (
|
||||
|
||||
if ( myIO & FLAG_FILE ) {
|
||||
|
||||
if ( !ReadFile (
|
||||
( HANDLE )myFileChannel, cBuffer, ( DWORD )NByte, &dwBytesRead, NULL
|
||||
)
|
||||
) { // an error occured
|
||||
if (!ReadFile (myFileHandle, cBuffer, (DWORD)NByte, &dwBytesRead, NULL)) { // an error occured
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
Buffer.Clear ();
|
||||
@ -1144,10 +1143,7 @@ void OSD_File :: ReadLine (
|
||||
if ( status == 0xFFFFFFFFFFFFFFFF ) { // last character in the buffer is <CR> -
|
||||
// peek next character to see if it is a <LF>
|
||||
#endif
|
||||
if ( !ReadFile (
|
||||
( HANDLE )myFileChannel, ppeekChar, 1, &dwDummy, NULL
|
||||
)
|
||||
) {
|
||||
if (!ReadFile (myFileHandle, ppeekChar, 1, &dwDummy, NULL)) {
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
@ -1157,7 +1153,7 @@ void OSD_File :: ReadLine (
|
||||
|
||||
// adjust file position
|
||||
|
||||
SetFilePointer ( ( HANDLE )myFileChannel, -1, NULL, FILE_CURRENT );
|
||||
SetFilePointer (myFileHandle, -1, NULL, FILE_CURRENT);
|
||||
|
||||
} else
|
||||
myIO |= FLAG_EOF;
|
||||
@ -1167,7 +1163,7 @@ void OSD_File :: ReadLine (
|
||||
} else {
|
||||
|
||||
if ( dwSeekPos != 0 )
|
||||
SetFilePointer ( ( HANDLE )myFileChannel, ( LONG )dwSeekPos, NULL, FILE_CURRENT );
|
||||
SetFilePointer (myFileHandle, (LONG)dwSeekPos, NULL, FILE_CURRENT);
|
||||
|
||||
NbyteRead = ( Standard_Integer )( eos - cBuffer );
|
||||
|
||||
@ -1177,10 +1173,8 @@ void OSD_File :: ReadLine (
|
||||
|
||||
} else if ( myIO & FLAG_SOCKET || myIO & FLAG_PIPE || myIO & FLAG_NAMED_PIPE ) {
|
||||
|
||||
dwBytesRead = ( DWORD )_get_buffer (
|
||||
( HANDLE )myFileChannel, cBuffer, ( DWORD )NByte,
|
||||
TRUE, myIO & FLAG_SOCKET
|
||||
);
|
||||
dwBytesRead = (DWORD)_get_buffer (myFileHandle, cBuffer,
|
||||
(DWORD)NByte, TRUE, myIO & FLAG_SOCKET);
|
||||
|
||||
if ( ( int )dwBytesRead == -1 ) { // an error occured
|
||||
|
||||
@ -1210,9 +1204,7 @@ void OSD_File :: ReadLine (
|
||||
|
||||
NbyteRead = dwBytesRead; // (LD) always fits this case.
|
||||
|
||||
dwDummy = _get_buffer (
|
||||
( HANDLE )myFileChannel, ppeekChar, 1, TRUE, myIO & FLAG_SOCKET
|
||||
);
|
||||
dwDummy = _get_buffer (myFileHandle, ppeekChar, 1, TRUE, myIO & FLAG_SOCKET);
|
||||
if ( ( int )dwDummy == -1 ) { // an error occured
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
@ -1239,9 +1231,8 @@ void OSD_File :: ReadLine (
|
||||
|
||||
Standard_PCharacter cDummyBuffer = new Standard_Character[ NByte + 3 ];
|
||||
|
||||
_get_buffer ( // remove pending input
|
||||
( HANDLE )myFileChannel, cDummyBuffer, dwBytesRead, FALSE, myIO & FLAG_SOCKET
|
||||
);
|
||||
// remove pending input
|
||||
_get_buffer (myFileHandle, cDummyBuffer, dwBytesRead, FALSE, myIO & FLAG_SOCKET);
|
||||
delete [] cDummyBuffer ;
|
||||
|
||||
} // end else
|
||||
@ -1258,183 +1249,6 @@ void OSD_File :: ReadLine (
|
||||
|
||||
} // end OSD_File :: ReadLine
|
||||
|
||||
#else // PRO13471
|
||||
|
||||
void OSD_File :: ReadLine (
|
||||
TCollection_AsciiString& Buffer,
|
||||
const Standard_Integer NByte, Standard_Integer& NbyteRead
|
||||
) {
|
||||
|
||||
DWORDLONG status;
|
||||
DWORD dwBytesRead;
|
||||
DWORD dwDummy;
|
||||
Standard_Character peekChar;
|
||||
Standard_CString cBuffer;
|
||||
Standard_CString eos;
|
||||
DWORD dwSeekPos;
|
||||
|
||||
if ( OSD_File::KindOfFile ( ) == OSD_DIRECTORY ) {
|
||||
Standard_ProgramError::Raise("OSD_File::Read : it is a directory");
|
||||
}
|
||||
|
||||
|
||||
TEST_RAISE( TEXT( "ReadLine" ) );
|
||||
|
||||
if ( myIO & FLAG_PIPE && !( myIO & FLAG_READ_PIPE ) )
|
||||
|
||||
RAISE( TEXT( "OSD_File :: ReadLine (): attempt to read from write only pipe" ) );
|
||||
|
||||
// +----> leave space for end-of-string
|
||||
// | plus <CR><LF> sequence
|
||||
// |
|
||||
cBuffer = new Standard_Character[ NByte + 3 ];
|
||||
|
||||
if ( myIO & FLAG_FILE ) {
|
||||
|
||||
if ( !ReadFile (
|
||||
( HANDLE )myFileChannel, cBuffer, ( DWORD )NByte, &dwBytesRead, NULL
|
||||
)
|
||||
) { // an error occured
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
Buffer.Clear ();
|
||||
NbyteRead = 0;
|
||||
|
||||
} else if ( dwBytesRead == 0 ) { // end-of-file reached
|
||||
|
||||
Buffer.Clear ();
|
||||
NbyteRead = 0;
|
||||
myIO |= FLAG_EOF;
|
||||
|
||||
} else {
|
||||
|
||||
status = _get_line ( cBuffer, dwBytesRead );
|
||||
|
||||
dwSeekPos = LODWORD( status );
|
||||
eos = ( Standard_CString )HIDWORD( status );
|
||||
#ifdef VAC
|
||||
if ( (__int64) status == (__int64) -1 ) { // last character in the buffer is <CR> -
|
||||
#else
|
||||
if ( status == 0xFFFFFFFFFFFFFFFF ) { // last character in the buffer is <CR> -
|
||||
// peek next character to see if it is a <LF>
|
||||
#endif
|
||||
if ( !ReadFile (
|
||||
( HANDLE )myFileChannel, &peekChar, 1, &dwDummy, NULL
|
||||
)
|
||||
) {
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
NbyteRead = dwBytesRead;
|
||||
|
||||
} else if ( dwDummy != 0 ) { // end-of-file reached ?
|
||||
|
||||
if ( peekChar == '\n' ) // we got a <CR><LF> sequence
|
||||
|
||||
cBuffer[ --dwBytesRead ] = 0;
|
||||
|
||||
else // adjust file position
|
||||
|
||||
SetFilePointer ( ( HANDLE )myFileChannel, -1, NULL, FILE_CURRENT );
|
||||
|
||||
} else
|
||||
|
||||
myIO |= FLAG_EOF;
|
||||
|
||||
NbyteRead = dwBytesRead;
|
||||
|
||||
} else if ( dwSeekPos != 0 ) {
|
||||
|
||||
SetFilePointer ( ( HANDLE )myFileChannel, ( LONG )dwSeekPos, NULL, FILE_CURRENT );
|
||||
NbyteRead = ( Standard_Integer )( eos - cBuffer );
|
||||
|
||||
} else
|
||||
|
||||
NbyteRead = eos - cBuffer;
|
||||
|
||||
} // end else
|
||||
|
||||
} else if ( myIO & FLAG_SOCKET || myIO & FLAG_PIPE || myIO & FLAG_NAMED_PIPE ) {
|
||||
|
||||
dwBytesRead = ( DWORD )_get_buffer (
|
||||
( HANDLE )myFileChannel, cBuffer, ( DWORD )NByte,
|
||||
TRUE, myIO & FLAG_SOCKET
|
||||
);
|
||||
|
||||
if ( ( int )dwBytesRead == -1 ) // an error occured
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
else if ( dwBytesRead == 0 ) { // connection closed - set end-of-file flag
|
||||
|
||||
Buffer.Clear ();
|
||||
NbyteRead = 0;
|
||||
myIO |= FLAG_EOF;
|
||||
|
||||
} else {
|
||||
|
||||
status = _get_line ( cBuffer, dwBytesRead );
|
||||
|
||||
dwSeekPos = LODWORD( status );
|
||||
eos = ( Standard_CString )HIDWORD( status );
|
||||
|
||||
#ifdef VAC
|
||||
if ( (__int64) status == (__int64) -1 ) { // last character in the buffer is <CR> -
|
||||
#else
|
||||
if ( status == 0xFFFFFFFFFFFFFFFF ) { // last character in the buffer is <CR> -
|
||||
// peek next character to see if it is a <LF>
|
||||
#endif
|
||||
dwDummy = _get_buffer (
|
||||
( HANDLE )myFileChannel, &peekChar, 1, TRUE, myIO & FLAG_SOCKET
|
||||
);
|
||||
eos = cBuffer + dwBytesRead;
|
||||
|
||||
if ( ( int )dwDummy == -1 ) { // an error occured
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
NbyteRead = dwBytesRead;
|
||||
|
||||
} else if ( dwDummy != 0 ) { // connection closed ?
|
||||
|
||||
if ( peekChar == '\n' ) // we got a <CR><LF> sequence
|
||||
|
||||
cBuffer[ dwBytesRead - 1 ] = 0, eos = cBuffer + ( dwBytesRead++ - 1 );
|
||||
|
||||
} else
|
||||
|
||||
myIO |= FLAG_EOF;
|
||||
|
||||
NbyteRead = dwBytesRead;
|
||||
|
||||
} else if ( dwSeekPos != 0 ) {
|
||||
|
||||
dwBytesRead = dwBytesRead + dwSeekPos;
|
||||
NbyteRead = ( Standard_Integer )( eos - cBuffer );
|
||||
|
||||
} else
|
||||
|
||||
NbyteRead = ( Standard_Integer )( eos - cBuffer );
|
||||
|
||||
_get_buffer ( // remove pending input
|
||||
( HANDLE )myFileChannel, cBuffer, dwBytesRead, FALSE, myIO & FLAG_SOCKET
|
||||
);
|
||||
*eos = 0;
|
||||
|
||||
} // end else
|
||||
|
||||
} else
|
||||
|
||||
RAISE( TEXT( "OSD_File :: ReadLine (): incorrect call - file is a directory" ) );
|
||||
|
||||
if ( !Failed () && !IsAtEnd () )
|
||||
|
||||
Buffer = cBuffer;
|
||||
|
||||
delete [] cBuffer;
|
||||
|
||||
} // end OSD_File :: ReadLine
|
||||
|
||||
#endif // PRO13471
|
||||
|
||||
// --------------------------------------------------------------------------
|
||||
// Read content of a file
|
||||
// --------------------------------------------------------------------------
|
||||
@ -1456,10 +1270,7 @@ void OSD_File :: Read (
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Read (): attempt to read from write only pipe" ) );
|
||||
|
||||
if ( !ReadFile (
|
||||
( HANDLE )myFileChannel, Buffer, ( DWORD )Nbyte, &dwBytesRead, NULL
|
||||
)
|
||||
) {
|
||||
if (!ReadFile (myFileHandle, Buffer, (DWORD)Nbyte, &dwBytesRead, NULL)) {
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
dwBytesRead = 0;
|
||||
@ -1502,10 +1313,8 @@ void OSD_File :: Write (
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Write (): attempt to write to read only pipe" ) );
|
||||
|
||||
if ( !WriteFile (
|
||||
( HANDLE )myFileChannel, Buffer, ( DWORD )Nbyte, &dwBytesWritten, NULL
|
||||
) || dwBytesWritten != ( DWORD )Nbyte
|
||||
)
|
||||
if (!WriteFile (myFileHandle, Buffer, (DWORD)Nbyte, &dwBytesWritten, NULL) ||
|
||||
dwBytesWritten != (DWORD)Nbyte)
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
@ -1547,10 +1356,7 @@ void OSD_File :: Seek (
|
||||
|
||||
} // end switch
|
||||
|
||||
if ( SetFilePointer (
|
||||
( HANDLE )myFileChannel, ( LONG )Offset, NULL, dwMoveMethod
|
||||
) == 0xFFFFFFFF
|
||||
)
|
||||
if (SetFilePointer (myFileHandle, (LONG)Offset, NULL, dwMoveMethod) == 0xFFFFFFFF)
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
@ -1568,9 +1374,9 @@ void OSD_File :: Close () {
|
||||
|
||||
TEST_RAISE( TEXT( "Close" ) );
|
||||
|
||||
CloseHandle ( ( HANDLE )myFileChannel );
|
||||
CloseHandle (myFileHandle);
|
||||
|
||||
myFileChannel = ( Standard_Integer )INVALID_HANDLE_VALUE;
|
||||
myFileHandle = INVALID_HANDLE_VALUE;
|
||||
myIO = 0;
|
||||
|
||||
} // end OSD_File :: Close
|
||||
@ -1594,7 +1400,7 @@ OSD_KindFile OSD_File :: KindOfFile () const {
|
||||
OSD_KindFile retVal;
|
||||
Standard_Integer flags;
|
||||
|
||||
if ( ( HANDLE )myFileChannel == INVALID_HANDLE_VALUE ) {
|
||||
if (myFileHandle == INVALID_HANDLE_VALUE) {
|
||||
|
||||
TCollection_AsciiString fName;
|
||||
|
||||
@ -1604,9 +1410,7 @@ OSD_KindFile OSD_File :: KindOfFile () const {
|
||||
|
||||
RAISE( TEXT( "OSD_File :: KindOfFile (): incorrent call - no filename given" ) );
|
||||
|
||||
flags = _get_file_type (
|
||||
fName.ToCString (), ( Standard_Integer )INVALID_HANDLE_VALUE
|
||||
);
|
||||
flags = _get_file_type (fName.ToCString(), INVALID_HANDLE_VALUE);
|
||||
|
||||
} else
|
||||
|
||||
@ -1794,10 +1598,9 @@ void OSD_File :: SetLock ( const OSD_LockType Lock ) {
|
||||
|
||||
dwFlags = 0;
|
||||
|
||||
if ( !LockFileEx (
|
||||
( HANDLE )myFileChannel, dwFlags, 0, Size (), 0, &ovlp
|
||||
)
|
||||
) {
|
||||
LARGE_INTEGER aSize;
|
||||
aSize.QuadPart = Size();
|
||||
if (!LockFileEx (myFileHandle, dwFlags, 0, aSize.LowPart, aSize.HighPart, &ovlp)) {
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
__leave;
|
||||
@ -1827,10 +1630,9 @@ void OSD_File :: UnLock () {
|
||||
|
||||
if ( ImperativeFlag ) {
|
||||
|
||||
if ( !UnlockFile (
|
||||
( HANDLE )myFileChannel, 0, 0, Size (), 0
|
||||
)
|
||||
)
|
||||
LARGE_INTEGER aSize;
|
||||
aSize.QuadPart = Size();
|
||||
if (!UnlockFile (myFileHandle, 0, 0, aSize.LowPart, aSize.HighPart))
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
@ -1859,21 +1661,21 @@ Standard_Boolean OSD_File :: IsLocked () {
|
||||
// Return size of a file
|
||||
// --------------------------------------------------------------------------
|
||||
|
||||
Standard_Integer OSD_File :: Size () {
|
||||
Standard_Size OSD_File :: Size () {
|
||||
|
||||
Standard_Integer retVal;
|
||||
|
||||
TEST_RAISE( TEXT( "Size" ) );
|
||||
|
||||
retVal = ( Standard_Integer )GetFileSize (
|
||||
( HANDLE )myFileChannel, NULL
|
||||
);
|
||||
LARGE_INTEGER aSize;
|
||||
aSize.QuadPart = 0;
|
||||
retVal = GetFileSizeEx (myFileHandle, &aSize);
|
||||
|
||||
if ( retVal == ( Standard_Integer )0xFFFFFFFF )
|
||||
if ( retVal == 0 )
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFile );
|
||||
|
||||
return retVal;
|
||||
return (Standard_Size)aSize.QuadPart;
|
||||
|
||||
} // end OSD_File :: Size
|
||||
|
||||
@ -1883,7 +1685,7 @@ Standard_Integer OSD_File :: Size () {
|
||||
|
||||
void OSD_File :: Print ( const OSD_Printer& WhichPrinter ) {
|
||||
|
||||
if ( ( HANDLE )myFileChannel != INVALID_HANDLE_VALUE )
|
||||
if (myFileHandle != INVALID_HANDLE_VALUE)
|
||||
|
||||
RAISE( TEXT( "OSD_File :: Print (): incorrect call - file opened" ) );
|
||||
|
||||
@ -1904,7 +1706,7 @@ void OSD_File :: Print ( const OSD_Printer& WhichPrinter ) {
|
||||
|
||||
Standard_Boolean OSD_File :: IsOpen () const {
|
||||
|
||||
return ( HANDLE )myFileChannel != INVALID_HANDLE_VALUE;
|
||||
return myFileHandle != INVALID_HANDLE_VALUE;
|
||||
|
||||
} // end OSD_File :: IsOpen
|
||||
|
||||
@ -2179,11 +1981,11 @@ leave: ; // added for VisualAge
|
||||
#undef __leave
|
||||
#endif
|
||||
|
||||
static void __fastcall _test_raise ( Standard_Integer hFile, Standard_CString str ) {
|
||||
static void __fastcall _test_raise ( HANDLE hFile, Standard_CString str ) {
|
||||
|
||||
Standard_Character buff[ 64 ];
|
||||
|
||||
if ( ( HANDLE )hFile == INVALID_HANDLE_VALUE ) {
|
||||
if (hFile == INVALID_HANDLE_VALUE) {
|
||||
|
||||
_tcscpy ( buff, TEXT( "OSD_File :: " ) );
|
||||
_tcscat ( buff, str );
|
||||
@ -2195,8 +1997,6 @@ static void __fastcall _test_raise ( Standard_Integer hFile, Standard_CString st
|
||||
|
||||
} // end _test_raise
|
||||
|
||||
#ifdef PRO13471
|
||||
|
||||
// Modified so that we have <nl> at end of line if we have read <nl> or <cr>
|
||||
// by LD 17 dec 98 for B4.4
|
||||
|
||||
@ -2261,76 +2061,6 @@ static DWORDLONG __fastcall _get_line ( Standard_PCharacter& buffer, DWORD dwBuf
|
||||
|
||||
} // end _get_line
|
||||
|
||||
#else // PRO13471
|
||||
|
||||
static DWORDLONG __fastcall _get_line ( Standard_CString buffer, DWORD dwBuffSize ) {
|
||||
|
||||
DWORDLONG retVal;
|
||||
Standard_CString ptr;
|
||||
|
||||
buffer[ dwBuffSize ] = 0;
|
||||
ptr = buffer;
|
||||
|
||||
while ( *ptr != 0 ) {
|
||||
|
||||
if ( *ptr == TEXT( '\n' ) ) {
|
||||
|
||||
retVal = buffer - ptr;
|
||||
#ifdef VAC
|
||||
buffer[ (__int64) -( LONGLONG )retVal ] = 0;
|
||||
#else
|
||||
buffer[ -( LONGLONG )retVal ] = 0;
|
||||
#endif
|
||||
retVal = ptr + 1 - buffer - dwBuffSize;
|
||||
#ifdef VAC
|
||||
retVal = (DWORDLONG) ( (unsigned __int64) retVal | (((unsigned __int64) ptr) << 32) );
|
||||
#else
|
||||
retVal |= ( ( ( DWORDLONG )( DWORD )ptr ) << 32 );
|
||||
#endif
|
||||
return retVal;
|
||||
|
||||
} else if ( *ptr == TEXT( '\r' ) && ptr[ 1 ] == TEXT( '\n' ) ) {
|
||||
|
||||
retVal = buffer - ptr;
|
||||
#ifdef VAC
|
||||
buffer[ (__int64) -( LONGLONG )retVal ] = 0;
|
||||
#else
|
||||
buffer[ -( LONGLONG )retVal ] = 0;
|
||||
#endif
|
||||
retVal = ptr + 2 - buffer - dwBuffSize;
|
||||
#ifdef VAC
|
||||
retVal = (DWORDLONG) ( (unsigned __int64) retVal | (((unsigned __int64) ptr) << 32) );
|
||||
#else
|
||||
retVal |= ( ( ( DWORDLONG )( DWORD )ptr ) << 32 );
|
||||
#endif
|
||||
return retVal;
|
||||
|
||||
} else if ( *ptr == TEXT( '\r' ) && ptr[ 1 ] == 0 )
|
||||
|
||||
#ifdef VAC
|
||||
return (DWORDLONG) (__int64) (-1);
|
||||
#else
|
||||
return 0xFFFFFFFFFFFFFFFF;
|
||||
#endif
|
||||
|
||||
++ptr;
|
||||
|
||||
} // end while
|
||||
|
||||
#ifdef VAC
|
||||
retVal = (DWORDLONG) ( ( (unsigned __int64) ((DWORD) buffer + dwBuffSize) ) << 32 );
|
||||
retVal = (DWORDLONG) ( (unsigned __int64) retVal & (((unsigned __int64) 0xFFFFFFFF) << 32) );
|
||||
#else
|
||||
retVal = ( ( ( DWORDLONG )( ( DWORD )buffer + dwBuffSize ) ) << 32 );
|
||||
retVal &= 0xFFFFFFFF00000000;
|
||||
#endif
|
||||
|
||||
return retVal;
|
||||
|
||||
} // end _get_line
|
||||
|
||||
#endif // PRO13471
|
||||
|
||||
static int __fastcall _get_buffer (
|
||||
HANDLE hChannel,
|
||||
Standard_PCharacter& buffer,
|
||||
@ -2676,16 +2406,15 @@ static HANDLE __fastcall _open_file (
|
||||
} // end _open_file
|
||||
|
||||
Standard_Integer __fastcall _get_file_type (
|
||||
Standard_CString fName, Standard_Integer fileHandle
|
||||
Standard_CString fName, HANDLE fileHandle
|
||||
) {
|
||||
|
||||
Standard_Integer retVal = 0;
|
||||
DWORD dwType;
|
||||
int fileType;
|
||||
|
||||
fileType = fileHandle == ( Standard_Integer )INVALID_HANDLE_VALUE ?
|
||||
FILE_TYPE_DISK :
|
||||
GetFileType ( ( HANDLE )fileHandle );
|
||||
fileType = (fileHandle == INVALID_HANDLE_VALUE ?
|
||||
FILE_TYPE_DISK : GetFileType (fileHandle));
|
||||
|
||||
switch ( fileType ) {
|
||||
|
||||
@ -3168,7 +2897,7 @@ Standard_Boolean OSD_File::IsExecutable()
|
||||
// if (_access(FileName.ToCString(),0))
|
||||
}
|
||||
|
||||
#endif // WNT
|
||||
#endif /* _WIN32 */
|
||||
|
||||
|
||||
// ---------------------------------------------------------------------
|
||||
|
@ -130,7 +130,6 @@ is
|
||||
|
||||
fields
|
||||
myPath : Path is protected; -- system independent path name
|
||||
myFileChannel : Integer is protected; -- file descriptor
|
||||
myError : Error is protected;
|
||||
end FileNode from OSD;
|
||||
|
||||
|
@ -20,7 +20,11 @@
|
||||
# include <config.h>
|
||||
#endif
|
||||
|
||||
#ifndef WNT
|
||||
#ifndef _WIN32
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
//------------------- Linux Sources of OSD_FileNode --------------------------
|
||||
//----------------------------------------------------------------------------
|
||||
|
||||
#include <unistd.h>
|
||||
#include <errno.h>
|
||||
@ -66,15 +70,14 @@ const OSD_WhoAmI Iam = OSD_WFileNode;
|
||||
|
||||
// Create a file/directory object
|
||||
|
||||
OSD_FileNode::OSD_FileNode (){
|
||||
myFileChannel = -1;
|
||||
OSD_FileNode::OSD_FileNode ()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
|
||||
// Create and initialize a file/directory object
|
||||
|
||||
OSD_FileNode::OSD_FileNode (const OSD_Path& Name){
|
||||
OSD_FileNode::OSD_FileNode (const OSD_Path& Name)
|
||||
{
|
||||
SetPath (Name);
|
||||
}
|
||||
|
||||
@ -191,15 +194,7 @@ TCollection_AsciiString thisPath;
|
||||
if (status == -1) myError.SetValue (errno, Iam, "Move");
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
// Copy a file to another path and name
|
||||
|
||||
|
||||
#ifndef WNT
|
||||
|
||||
int static copy_file( const char* src, const char* trg )
|
||||
{
|
||||
int err=0;
|
||||
@ -236,11 +231,6 @@ int static copy_file( const char* src, const char* trg )
|
||||
return err;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
|
||||
void OSD_FileNode::Copy(const OSD_Path& ToPath)
|
||||
{
|
||||
int status;
|
||||
@ -441,7 +431,7 @@ Standard_Integer OSD_FileNode::Error()const{
|
||||
return( myError.Error());
|
||||
}
|
||||
|
||||
#else
|
||||
#else /* _WIN32 */
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
//------------------- WNT Sources of OSD_FileNode ---------------------------
|
||||
@ -466,7 +456,7 @@ PSECURITY_DESCRIPTOR __fastcall _osd_wnt_protection_to_sd ( const OSD_Protection
|
||||
BOOL __fastcall _osd_wnt_sd_to_protection (
|
||||
PSECURITY_DESCRIPTOR pSD, OSD_Protection& prot, BOOL
|
||||
);
|
||||
Standard_Integer __fastcall _get_file_type ( Standard_CString, Standard_Integer );
|
||||
Standard_Integer __fastcall _get_file_type ( Standard_CString, HANDLE );
|
||||
|
||||
void _osd_wnt_set_error ( OSD_Error&, OSD_WhoAmI, ... );
|
||||
|
||||
@ -478,22 +468,18 @@ static void __fastcall _test_raise ( TCollection_AsciiString, Standard_CString )
|
||||
//purpose : Empty Constructor
|
||||
//=======================================================================
|
||||
|
||||
OSD_FileNode::OSD_FileNode () {
|
||||
|
||||
myFileChannel = ( Standard_Integer )INVALID_HANDLE_VALUE;
|
||||
|
||||
} // end constructor ( 1 )
|
||||
OSD_FileNode::OSD_FileNode ()
|
||||
{
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : OSD_FileNode
|
||||
//purpose : Constructor
|
||||
//=======================================================================
|
||||
|
||||
OSD_FileNode::OSD_FileNode ( const OSD_Path& Name ) {
|
||||
|
||||
myFileChannel = ( Standard_Integer )INVALID_HANDLE_VALUE;
|
||||
OSD_FileNode::OSD_FileNode ( const OSD_Path& Name )
|
||||
{
|
||||
myPath = Name;
|
||||
|
||||
} // end constructor ( 2 )
|
||||
|
||||
//=======================================================================
|
||||
@ -560,8 +546,7 @@ void OSD_FileNode::Remove () {
|
||||
|
||||
TEST_RAISE( TEXT( "Remove" ) );
|
||||
|
||||
switch ( _get_file_type ( fName.ToCString (),
|
||||
( Standard_Integer )INVALID_HANDLE_VALUE ) ) {
|
||||
switch (_get_file_type (fName.ToCString(), INVALID_HANDLE_VALUE)) {
|
||||
|
||||
case FLAG_FILE:
|
||||
|
||||
@ -608,8 +593,7 @@ void OSD_FileNode::Move ( const OSD_Path& NewPath ) {
|
||||
|
||||
NewPath.SystemName ( fNameDst );
|
||||
|
||||
switch ( _get_file_type ( fName.ToCString (),
|
||||
( Standard_Integer )INVALID_HANDLE_VALUE ) ) {
|
||||
switch (_get_file_type (fName.ToCString (), INVALID_HANDLE_VALUE)) {
|
||||
|
||||
case FLAG_FILE:
|
||||
|
||||
@ -659,8 +643,7 @@ void OSD_FileNode::Copy ( const OSD_Path& ToPath ) {
|
||||
|
||||
ToPath.SystemName ( fNameDst );
|
||||
|
||||
switch ( _get_file_type ( fName.ToCString (),
|
||||
( Standard_Integer )INVALID_HANDLE_VALUE ) ) {
|
||||
switch (_get_file_type (fName.ToCString(), INVALID_HANDLE_VALUE)) {
|
||||
|
||||
case FLAG_FILE:
|
||||
|
||||
@ -713,9 +696,7 @@ OSD_Protection OSD_FileNode::Protection () {
|
||||
) == NULL ||
|
||||
!_osd_wnt_sd_to_protection (
|
||||
pSD, retVal,
|
||||
_get_file_type ( fName.ToCString (), ( Standard_Integer )INVALID_HANDLE_VALUE ) ==
|
||||
FLAG_DIRECTORY
|
||||
)
|
||||
_get_file_type (fName.ToCString(), INVALID_HANDLE_VALUE) == FLAG_DIRECTORY)
|
||||
)
|
||||
|
||||
_osd_wnt_set_error ( myError, OSD_WFileNode );
|
||||
@ -744,8 +725,7 @@ void OSD_FileNode::SetProtection ( const OSD_Protection& Prot ) {
|
||||
|
||||
pSD = _osd_wnt_protection_to_sd (
|
||||
Prot,
|
||||
_get_file_type ( fName.ToCString (),
|
||||
( Standard_Integer )INVALID_HANDLE_VALUE ) ==
|
||||
_get_file_type (fName.ToCString(), INVALID_HANDLE_VALUE) ==
|
||||
FLAG_DIRECTORY,
|
||||
(char *)fName.ToCString ()
|
||||
);
|
||||
@ -1060,4 +1040,4 @@ static void __fastcall _test_raise ( TCollection_AsciiString fName, Standard_CSt
|
||||
|
||||
} // end _test_raise
|
||||
|
||||
#endif
|
||||
#endif /* _WIN32 */
|
||||
|
@ -345,7 +345,7 @@ Handle_StlMesh_Mesh RWStl::ReadBinary (const OSD_Path& thePath,
|
||||
// must be a multiple of SIZEOF_STL_FACET
|
||||
|
||||
// compute file size
|
||||
Standard_Integer filesize = theFile.Size();
|
||||
Standard_Size filesize = theFile.Size();
|
||||
|
||||
if ( (filesize - HEADER_SIZE) % SIZEOF_STL_FACET !=0
|
||||
|| (filesize < STL_MIN_FILE_SIZE)) {
|
||||
@ -354,7 +354,7 @@ Handle_StlMesh_Mesh RWStl::ReadBinary (const OSD_Path& thePath,
|
||||
|
||||
// don't trust the number of triangles which is coded in the file
|
||||
// sometimes it is wrong, and with this technique we don't need to swap endians for integer
|
||||
NBFACET = ((filesize - HEADER_SIZE) / SIZEOF_STL_FACET);
|
||||
NBFACET = (Standard_Integer)((filesize - HEADER_SIZE) / SIZEOF_STL_FACET);
|
||||
|
||||
// skip the header
|
||||
theFile.Seek(HEADER_SIZE,OSD_FromBeginning);
|
||||
|
Loading…
x
Reference in New Issue
Block a user