mirror of
https://github.com/tesseract-ocr/tesseract.git
synced 2024-12-28 19:18:20 +08:00
c383b1aaca
Signed-off-by: Stefan Weil <sw@weilnetz.de>
163 lines
6.4 KiB
C++
163 lines
6.4 KiB
C++
/**********************************************************************
|
|
* 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
|
|
|
|
#include <cstdlib>
|
|
#include <cstring>
|
|
#include <cstdio>
|
|
#include "host.h"
|
|
|
|
template <typename T> class GenericVector;
|
|
class STRING;
|
|
|
|
/***********************************************************************
|
|
QUOTE_IT MACRO DEFINITION
|
|
===========================
|
|
Replace <parm> with "<parm>". <parm> may be an arbitrary number of tokens
|
|
***********************************************************************/
|
|
|
|
#define QUOTE_IT( parm ) #parm
|
|
|
|
namespace tesseract {
|
|
|
|
// Return number of elements of an array.
|
|
template <typename T, size_t N>
|
|
constexpr size_t countof(T const (&)[N]) noexcept {
|
|
return N;
|
|
}
|
|
|
|
// 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);
|
|
|
|
// Deserialize data from file.
|
|
bool DeSerialize(FILE* fp, char* data, size_t n = 1);
|
|
bool DeSerialize(FILE* fp, float* data, size_t n = 1);
|
|
bool DeSerialize(FILE* fp, int8_t* data, size_t n = 1);
|
|
bool DeSerialize(FILE* fp, int16_t* data, size_t n = 1);
|
|
bool DeSerialize(FILE* fp, int32_t* data, size_t n = 1);
|
|
bool DeSerialize(FILE* fp, uint8_t* data, size_t n = 1);
|
|
bool DeSerialize(FILE* fp, uint16_t* data, size_t n = 1);
|
|
bool DeSerialize(FILE* fp, uint32_t* data, size_t n = 1);
|
|
|
|
// Serialize data to file.
|
|
bool Serialize(FILE* fp, const char* data, size_t n = 1);
|
|
bool Serialize(FILE* fp, const float* data, size_t n = 1);
|
|
bool Serialize(FILE* fp, const int8_t* data, size_t n = 1);
|
|
bool Serialize(FILE* fp, const int16_t* data, size_t n = 1);
|
|
bool Serialize(FILE* fp, const int32_t* data, size_t n = 1);
|
|
bool Serialize(FILE* fp, const uint8_t* data, size_t n = 1);
|
|
bool Serialize(FILE* fp, const uint16_t* data, size_t n = 1);
|
|
bool Serialize(FILE* fp, const uint32_t* data, size_t n = 1);
|
|
|
|
// Simple file class.
|
|
// Allows for portable file input from memory and from foreign file systems.
|
|
class TFile {
|
|
public:
|
|
TFile();
|
|
~TFile();
|
|
|
|
// All the Open methods load the whole file into memory for reading.
|
|
// Opens a file with a supplied reader, or nullptr to use the default.
|
|
// Note that mixed read/write is not supported.
|
|
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.
|
|
bool Open(FILE* fp, int64_t end_offset);
|
|
// Sets the value of the swap flag, so that FReadEndian does the right thing.
|
|
void set_swap(bool value) { swap_ = value; }
|
|
|
|
// Deserialize data.
|
|
bool DeSerialize(char* data, size_t count = 1);
|
|
bool DeSerialize(double* data, size_t count = 1);
|
|
bool DeSerialize(float* data, size_t count = 1);
|
|
bool DeSerialize(int8_t* data, size_t count = 1);
|
|
bool DeSerialize(int16_t* data, size_t count = 1);
|
|
bool DeSerialize(int32_t* data, size_t count = 1);
|
|
bool DeSerialize(int64_t* data, size_t count = 1);
|
|
bool DeSerialize(uint8_t* data, size_t count = 1);
|
|
bool DeSerialize(uint16_t* data, size_t count = 1);
|
|
bool DeSerialize(uint32_t* data, size_t count = 1);
|
|
bool DeSerialize(uint64_t* data, size_t count = 1);
|
|
|
|
// Serialize data.
|
|
bool Serialize(const char* data, size_t count = 1);
|
|
bool Serialize(const double* data, size_t count = 1);
|
|
bool Serialize(const float* data, size_t count = 1);
|
|
bool Serialize(const int8_t* data, size_t count = 1);
|
|
bool Serialize(const int16_t* data, size_t count = 1);
|
|
bool Serialize(const int32_t* data, size_t count = 1);
|
|
bool Serialize(const int64_t* data, size_t count = 1);
|
|
bool Serialize(const uint8_t* data, size_t count = 1);
|
|
bool Serialize(const uint16_t* data, size_t count = 1);
|
|
bool Serialize(const uint32_t* data, size_t count = 1);
|
|
bool Serialize(const uint64_t* data, size_t count = 1);
|
|
|
|
// Skip data.
|
|
bool Skip(size_t count);
|
|
|
|
// Reads a line like fgets. Returns nullptr on EOF, otherwise buffer.
|
|
// Reads at most buffer_size bytes, including '\0' terminator, even if
|
|
// the line is longer. Does nothing if buffer_size <= 0.
|
|
// To use fscanf use FGets and sscanf.
|
|
char* FGets(char* buffer, int buffer_size);
|
|
// Replicates fread, followed by a swap of the bytes if needed, returning the
|
|
// number of items read. If swap_ is true then the count items will each have
|
|
// size bytes reversed.
|
|
int FReadEndian(void* buffer, size_t size, int count);
|
|
// Replicates fread, returning the number of items read.
|
|
int FRead(void* buffer, size_t size, int count);
|
|
// Resets the TFile as if it has been Opened, but nothing read.
|
|
// Only allowed while reading!
|
|
void Rewind();
|
|
|
|
// Open for writing. Either supply a non-nullptr data with OpenWrite before
|
|
// calling FWrite, (no close required), or supply a nullptr data to OpenWrite
|
|
// 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, size_t size, int count);
|
|
|
|
private:
|
|
// The number of bytes used so far.
|
|
int offset_;
|
|
// The buffered data from the file.
|
|
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_;
|
|
// True if bytes need to be swapped in FReadEndian.
|
|
bool swap_;
|
|
};
|
|
|
|
} // namespace tesseract.
|
|
|
|
#endif
|