2008-06-11 14:52:57 +04:00
|
|
|
// $Id$
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------- */
|
|
|
|
/* Copyright 2005 (c) by RWTH Aachen - Lehrstuhl fuer Informatik VI */
|
|
|
|
/* Richard Zens */
|
|
|
|
/* ---------------------------------------------------------------- */
|
2010-02-24 14:15:44 +03:00
|
|
|
#ifndef moses_File_h
|
|
|
|
#define moses_File_h
|
|
|
|
|
2008-06-11 14:52:57 +04:00
|
|
|
#include <cstdio>
|
|
|
|
#include <iostream>
|
2014-01-13 22:32:22 +04:00
|
|
|
#include <sstream>
|
2008-06-11 14:52:57 +04:00
|
|
|
#include <vector>
|
2013-11-19 17:19:23 +04:00
|
|
|
#include "util/exception.hh"
|
2015-10-03 03:05:46 +03:00
|
|
|
#include "util/string_stream.hh"
|
2008-06-11 14:52:57 +04:00
|
|
|
#include "TypeDef.h"
|
|
|
|
#include "Util.h"
|
|
|
|
|
2008-10-09 03:51:26 +04:00
|
|
|
namespace Moses
|
|
|
|
{
|
|
|
|
|
2008-06-11 14:52:57 +04:00
|
|
|
#ifdef WIN32
|
2013-12-19 00:15:39 +04:00
|
|
|
#ifdef __MINGW32__
|
|
|
|
#define OFF_T __int64
|
|
|
|
#define FTELLO(f) ftello64(f)
|
|
|
|
#define FSEEKO(file, offset, origin) fseeko64(file, offset, origin)
|
|
|
|
#else
|
2011-02-24 16:14:42 +03:00
|
|
|
#define OFF_T __int64
|
2008-06-11 14:52:57 +04:00
|
|
|
#define FTELLO(file) _ftelli64(file)
|
|
|
|
#define FSEEKO(file, offset, origin) _fseeki64(file, offset, origin)
|
2013-12-19 00:15:39 +04:00
|
|
|
#endif
|
2008-06-11 14:52:57 +04:00
|
|
|
|
|
|
|
#else
|
2011-02-24 16:14:42 +03:00
|
|
|
#define OFF_T off_t
|
2008-06-11 14:52:57 +04:00
|
|
|
#define FTELLO(f) ftello(f)
|
|
|
|
#define FSEEKO(file, offset, origin) fseeko(file, offset, origin)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static const OFF_T InvalidOffT=-1;
|
|
|
|
|
|
|
|
// WARNING:
|
|
|
|
// these functions work only for bitwise read/write-able types
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
template<typename T> inline size_t fWrite(FILE* f,const T& t)
|
|
|
|
{
|
|
|
|
if(fwrite(&t,sizeof(t),1,f)!=1) {
|
2014-01-15 19:42:02 +04:00
|
|
|
UTIL_THROW2("ERROR:: fwrite!");
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
2008-06-11 14:52:57 +04:00
|
|
|
return sizeof(t);
|
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
template<typename T> inline void fRead(FILE* f,T& t)
|
|
|
|
{
|
|
|
|
if(fread(&t,sizeof(t),1,f)!=1) {
|
2014-01-15 19:42:02 +04:00
|
|
|
UTIL_THROW2("ERROR: fread!");
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
2008-06-11 14:52:57 +04:00
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
template<typename T> inline size_t fWrite(FILE* f,const T* b,const T* e)
|
|
|
|
{
|
2015-03-25 03:55:39 +03:00
|
|
|
uint32_t s=std::distance(b,e);
|
2011-02-24 16:14:42 +03:00
|
|
|
size_t rv=fWrite(f,s);
|
|
|
|
if(fwrite(b,sizeof(T),s,f)!=s) {
|
2014-01-15 19:42:02 +04:00
|
|
|
UTIL_THROW2("ERROR: fwrite!");
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
2008-06-11 14:52:57 +04:00
|
|
|
return rv+sizeof(T)*s;
|
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
template<typename T> inline size_t fWrite(FILE* f,const T b,const T e)
|
|
|
|
{
|
2015-03-25 03:55:39 +03:00
|
|
|
uint32_t s=std::distance(b,e);
|
2011-02-24 16:14:42 +03:00
|
|
|
size_t rv=fWrite(f,s);
|
|
|
|
if(fwrite(&(*b),sizeof(T),s,f)!=s) {
|
2014-01-15 19:42:02 +04:00
|
|
|
UTIL_THROW2("ERROR: fwrite!");
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
2008-06-11 14:52:57 +04:00
|
|
|
return rv+sizeof(T)*s;
|
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
template<typename C> inline size_t fWriteVector(FILE* f,const C& v)
|
|
|
|
{
|
2015-03-25 03:55:39 +03:00
|
|
|
uint32_t s=v.size();
|
2008-06-11 14:52:57 +04:00
|
|
|
size_t rv=fWrite(f,s);
|
2011-02-24 16:14:42 +03:00
|
|
|
if(fwrite(&v[0],sizeof(typename C::value_type),s,f)!=s) {
|
2014-01-15 19:42:02 +04:00
|
|
|
UTIL_THROW2("ERROR: fwrite!");
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
2008-06-11 14:52:57 +04:00
|
|
|
return rv+sizeof(typename C::value_type)*s;
|
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
template<typename C> inline void fReadVector(FILE* f, C& v)
|
|
|
|
{
|
2015-03-25 03:55:39 +03:00
|
|
|
uint32_t s;
|
2011-02-24 16:14:42 +03:00
|
|
|
fRead(f,s);
|
|
|
|
v.resize(s);
|
2008-06-11 14:52:57 +04:00
|
|
|
size_t r=fread(&(*v.begin()),sizeof(typename C::value_type),s,f);
|
2011-02-24 16:14:42 +03:00
|
|
|
if(r!=s) {
|
2014-01-15 19:42:02 +04:00
|
|
|
UTIL_THROW2("ERROR: freadVec! "<<r<<" "<<s);
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
2008-09-12 22:09:06 +04:00
|
|
|
}
|
|
|
|
|
2015-03-25 03:55:39 +03:00
|
|
|
inline size_t fWriteString(FILE* f,const char* e, uint32_t s)
|
2011-02-24 16:14:42 +03:00
|
|
|
{
|
2008-09-12 22:09:06 +04:00
|
|
|
size_t rv=fWrite(f,s);
|
2011-02-24 16:14:42 +03:00
|
|
|
if(fwrite(e,sizeof(char),s,f)!=s) {
|
2014-01-13 22:32:22 +04:00
|
|
|
UTIL_THROW2("ERROR:: fwrite!");
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
|
|
|
return rv+sizeof(char)*s;
|
2008-09-12 22:09:06 +04:00
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
inline void fReadString(FILE* f,std::string& e)
|
|
|
|
{
|
2015-03-25 03:55:39 +03:00
|
|
|
uint32_t s;
|
2011-02-24 16:14:42 +03:00
|
|
|
fRead(f,s);
|
|
|
|
char* a=new char[s+1];
|
|
|
|
if(fread(a,sizeof(char),s,f)!=s) {
|
2014-01-15 19:42:02 +04:00
|
|
|
UTIL_THROW2("ERROR: fread!");
|
2011-02-24 16:14:42 +03:00
|
|
|
}
|
|
|
|
a[s]='\0';
|
|
|
|
e.assign(a);
|
2011-03-25 20:42:21 +03:00
|
|
|
delete[](a);
|
2008-09-12 22:09:06 +04:00
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
inline size_t fWriteStringVector(FILE* f,const std::vector<std::string>& v)
|
|
|
|
{
|
2015-03-25 03:55:39 +03:00
|
|
|
uint32_t s=v.size();
|
2008-09-12 22:09:06 +04:00
|
|
|
size_t totrv=fWrite(f,s);
|
2011-02-24 16:14:42 +03:00
|
|
|
for (size_t i=0; i<s; i++) {
|
|
|
|
totrv+=fWriteString(f,v.at(i).c_str(),v.at(i).size());
|
|
|
|
}
|
2008-09-12 22:09:06 +04:00
|
|
|
return totrv;
|
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
inline void fReadStringVector(FILE* f, std::vector<std::string>& v)
|
|
|
|
{
|
2015-03-25 03:55:39 +03:00
|
|
|
uint32_t s;
|
2011-02-24 16:14:42 +03:00
|
|
|
fRead(f,s);
|
|
|
|
v.resize(s);
|
|
|
|
|
|
|
|
for (size_t i=0; i<s; i++) {
|
|
|
|
fReadString(f,v.at(i));
|
|
|
|
}
|
2008-06-11 14:52:57 +04:00
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
inline OFF_T fTell(FILE* f)
|
|
|
|
{
|
|
|
|
return FTELLO(f);
|
|
|
|
}
|
2008-06-11 14:52:57 +04:00
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
inline void fSeek(FILE* f,OFF_T o)
|
|
|
|
{
|
2008-06-11 14:52:57 +04:00
|
|
|
if(FSEEKO(f,o,SEEK_SET)<0) {
|
2015-10-16 22:17:00 +03:00
|
|
|
util::StringStream strme;
|
2014-01-15 19:42:02 +04:00
|
|
|
strme << "ERROR: could not fseeko position " << o <<"\n";
|
2014-01-13 22:32:22 +04:00
|
|
|
if(o==InvalidOffT) strme << "You tried to seek for 'InvalidOffT'!\n";
|
|
|
|
UTIL_THROW2(strme.str());
|
2008-06-11 14:52:57 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-02-24 16:14:42 +03:00
|
|
|
inline FILE* fOpen(const char* fn,const char* m)
|
|
|
|
{
|
|
|
|
if(FILE* f=fopen(fn,m))
|
|
|
|
return f;
|
|
|
|
else {
|
2015-01-07 07:07:06 +03:00
|
|
|
UTIL_THROW(util::Exception, "ERROR: could not open file " << fn << " with mode " << m);
|
2011-02-24 16:14:42 +03:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
inline void fClose(FILE* f)
|
|
|
|
{
|
|
|
|
fclose(f); // for consistent function names only
|
2008-06-11 14:52:57 +04:00
|
|
|
}
|
|
|
|
|
2008-10-09 03:51:26 +04:00
|
|
|
}
|
|
|
|
|
2008-06-11 14:52:57 +04:00
|
|
|
#endif
|