2007-03-08 04:03:40 +08:00
|
|
|
/**********************************************************************
|
|
|
|
* File: serialis.h (Formerly serialmac.h)
|
|
|
|
* Description: Inline routines and macros for serialisation functions
|
|
|
|
* Author: Phil Cheatle
|
|
|
|
* Created: Tue Oct 08 08:33:12 BST 1991
|
|
|
|
*
|
|
|
|
* (C) Copyright 1990, Hewlett-Packard Ltd.
|
|
|
|
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
** you may not use this file except in compliance with the License.
|
|
|
|
** You may obtain a copy of the License at
|
|
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
** Unless required by applicable law or agreed to in writing, software
|
|
|
|
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
** See the License for the specific language governing permissions and
|
|
|
|
** limitations under the License.
|
|
|
|
*
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#ifndef SERIALIS_H
|
|
|
|
#define SERIALIS_H
|
|
|
|
|
2014-08-12 07:09:25 +08:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "host.h"
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2014-08-12 07:09:25 +08:00
|
|
|
template <typename T> class GenericVector;
|
|
|
|
class STRING;
|
2007-03-08 04:03:40 +08:00
|
|
|
|
|
|
|
/***********************************************************************
|
|
|
|
QUOTE_IT MACRO DEFINITION
|
|
|
|
===========================
|
|
|
|
Replace <parm> with "<parm>". <parm> may be an arbitrary number of tokens
|
|
|
|
***********************************************************************/
|
|
|
|
|
|
|
|
#define QUOTE_IT( parm ) #parm
|
|
|
|
|
2013-10-10 10:07:26 +08:00
|
|
|
namespace tesseract {
|
|
|
|
|
2014-08-12 07:09:25 +08:00
|
|
|
// Function to read a GenericVector<char> from a whole file.
|
|
|
|
// Returns false on failure.
|
|
|
|
typedef bool (*FileReader)(const STRING& filename, GenericVector<char>* data);
|
|
|
|
// Function to write a GenericVector<char> to a whole file.
|
|
|
|
// Returns false on failure.
|
|
|
|
typedef bool (*FileWriter)(const GenericVector<char>& data,
|
|
|
|
const STRING& filename);
|
|
|
|
|
|
|
|
// Simple file class.
|
|
|
|
// Allows for portable file input from memory and from foreign file systems.
|
2013-10-10 10:07:26 +08:00
|
|
|
class TFile {
|
|
|
|
public:
|
|
|
|
TFile();
|
2014-08-12 07:09:25 +08:00
|
|
|
~TFile();
|
2013-10-10 10:07:26 +08:00
|
|
|
|
2014-08-12 07:09:25 +08:00
|
|
|
// All the Open methods load the whole file into memory for reading.
|
2016-12-13 00:20:28 +08:00
|
|
|
// Opens a file with a supplied reader, or nullptr to use the default.
|
2014-08-12 07:09:25 +08:00
|
|
|
// Note that mixed read/write is not supported.
|
2013-10-10 10:07:26 +08:00
|
|
|
bool Open(const STRING& filename, FileReader reader);
|
|
|
|
// From an existing memory buffer.
|
|
|
|
bool Open(const char* data, int size);
|
|
|
|
// From an open file and an end offset.
|
2018-03-14 02:01:40 +08:00
|
|
|
bool Open(FILE* fp, int64_t end_offset);
|
2017-05-04 07:09:44 +08:00
|
|
|
// Sets the value of the swap flag, so that FReadEndian does the right thing.
|
|
|
|
void set_swap(bool value) { swap_ = value; }
|
2013-10-10 10:07:26 +08:00
|
|
|
|
2016-12-13 00:20:28 +08:00
|
|
|
// Reads a line like fgets. Returns nullptr on EOF, otherwise buffer.
|
2013-10-10 10:07:26 +08:00
|
|
|
// Reads at most buffer_size bytes, including '\0' terminator, even if
|
|
|
|
// the line is longer. Does nothing if buffer_size <= 0.
|
2014-08-12 07:09:25 +08:00
|
|
|
// To use fscanf use FGets and sscanf.
|
2013-10-10 10:07:26 +08:00
|
|
|
char* FGets(char* buffer, int buffer_size);
|
2017-04-28 06:48:23 +08:00
|
|
|
// Replicates fread, followed by a swap of the bytes if needed, returning the
|
2017-05-04 07:09:44 +08:00
|
|
|
// number of items read. If swap_ is true then the count items will each have
|
2017-04-28 06:48:23 +08:00
|
|
|
// size bytes reversed.
|
2017-05-04 07:09:44 +08:00
|
|
|
int FReadEndian(void* buffer, int size, int count);
|
2013-10-10 10:07:26 +08:00
|
|
|
// Replicates fread, returning the number of items read.
|
|
|
|
int FRead(void* buffer, int size, int count);
|
|
|
|
// Resets the TFile as if it has been Opened, but nothing read.
|
2014-08-12 07:09:25 +08:00
|
|
|
// Only allowed while reading!
|
|
|
|
void Rewind();
|
|
|
|
|
2016-12-13 00:20:28 +08:00
|
|
|
// Open for writing. Either supply a non-nullptr data with OpenWrite before
|
|
|
|
// calling FWrite, (no close required), or supply a nullptr data to OpenWrite
|
2014-08-12 07:09:25 +08:00
|
|
|
// and call CloseWrite to write to a file after the FWrites.
|
|
|
|
void OpenWrite(GenericVector<char>* data);
|
|
|
|
bool CloseWrite(const STRING& filename, FileWriter writer);
|
|
|
|
|
|
|
|
// Replicates fwrite, returning the number of items written.
|
|
|
|
// To use fprintf, use snprintf and FWrite.
|
|
|
|
int FWrite(const void* buffer, int size, int count);
|
2013-10-10 10:07:26 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
// The number of bytes used so far.
|
|
|
|
int offset_;
|
|
|
|
// The buffered data from the file.
|
2014-08-12 07:09:25 +08:00
|
|
|
GenericVector<char>* data_;
|
|
|
|
// True if the data_ pointer is owned by *this.
|
|
|
|
bool data_is_owned_;
|
|
|
|
// True if the TFile is open for writing.
|
|
|
|
bool is_writing_;
|
2017-05-04 07:09:44 +08:00
|
|
|
// True if bytes need to be swapped in FReadEndian.
|
|
|
|
bool swap_;
|
2013-10-10 10:07:26 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace tesseract.
|
|
|
|
|
2007-03-08 04:03:40 +08:00
|
|
|
#endif
|