blob: 59b4f065869ac944d50cd5a756d758faefb387f9 [file] [log] [blame]
ANTLR_BEGIN_NAMESPACE()
template<class ImplTraits>
ANTLR_FDSC FileUtils<ImplTraits>::AntlrFopen(const ANTLR_UINT8* filename, const char * mode)
{
return (ANTLR_FDSC)fopen((const char *)filename, mode);
}
template<class ImplTraits>
void FileUtils<ImplTraits>::AntlrFclose (ANTLR_FDSC fd)
{
fclose(fd);
}
template<class ImplTraits>
ANTLR_UINT32 FileUtils<ImplTraits>::AntlrFsize(const ANTLR_UINT8* filename)
{
struct _stat statbuf;
_stat((const char *)filename, &statbuf);
return (ANTLR_UINT32)statbuf.st_size;
}
template<class ImplTraits>
ANTLR_UINT32 FileUtils<ImplTraits>::AntlrFread(ANTLR_FDSC fdsc, ANTLR_UINT32 count, void* data)
{
return (ANTLR_UINT32)fread(data, (size_t)count, 1, fdsc);
}
template<class ImplTraits>
template<typename InputStreamType>
ANTLR_UINT32 FileUtils<ImplTraits>::AntlrRead8Bit(InputStreamType* input, const ANTLR_UINT8* fileName)
{
ANTLR_FDSC infile;
ANTLR_UINT32 fSize;
/* Open the OS file in read binary mode
*/
infile = FileUtils<ImplTraits>::AntlrFopen(fileName, "rb");
/* Check that it was there
*/
if (infile == NULL)
{
ParseFileAbsentException ex;
throw ex;
}
/* It was there, so we can read the bytes now
*/
fSize = FileUtils<ImplTraits>::AntlrFsize(fileName); /* Size of input file */
/* Allocate buffer for this input set
*/
void* data = ImplTraits::AllocPolicyType::alloc(fSize);
/* Now we read the file. Characters are not converted to
* the internal ANTLR encoding until they are read from the buffer
*/
FileUtils<ImplTraits>::AntlrFread(infile, fSize, data );
input->set_data( (unsigned char*) data );
input->set_sizeBuf( fSize );
input->set_isAllocated(true);
/* And close the file handle
*/
FileUtils<ImplTraits>::AntlrFclose(infile);
return ANTLR_SUCCESS;
}
ANTLR_END_NAMESPACE()