2016-11-21 20:14:09 +08:00
|
|
|
//
|
|
|
|
// FileHolder.cpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 21/11/2016.
|
|
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "FileHolder.hpp"
|
|
|
|
|
2016-11-21 20:47:16 +08:00
|
|
|
#include <cstring>
|
|
|
|
|
2016-11-21 20:14:09 +08:00
|
|
|
using namespace Storage;
|
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
FileHolder::~FileHolder() {
|
2016-11-21 20:14:09 +08:00
|
|
|
if(file_) fclose(file_);
|
|
|
|
}
|
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
FileHolder::FileHolder(const std::string &file_name) : file_(nullptr), name_(file_name) {
|
|
|
|
stat(file_name.c_str(), &file_stats_);
|
2016-12-28 20:09:14 -05:00
|
|
|
is_read_only_ = false;
|
2017-07-22 16:02:25 -04:00
|
|
|
file_ = fopen(file_name.c_str(), "rb+");
|
|
|
|
if(!file_) {
|
2016-12-28 20:09:14 -05:00
|
|
|
is_read_only_ = true;
|
2017-07-22 16:02:25 -04:00
|
|
|
file_ = fopen(file_name.c_str(), "rb");
|
2016-12-28 20:09:14 -05:00
|
|
|
}
|
2016-11-21 20:14:09 +08:00
|
|
|
if(!file_) throw ErrorCantOpen;
|
|
|
|
}
|
2016-11-21 20:47:16 +08:00
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
bool FileHolder::check_signature(const char *signature, size_t length) {
|
2016-11-21 20:47:16 +08:00
|
|
|
if(!length) length = strlen(signature)+1;
|
|
|
|
|
|
|
|
// read and check the file signature
|
|
|
|
char stored_signature[12];
|
|
|
|
if(fread(stored_signature, 1, length, file_) != length) return false;
|
|
|
|
if(memcmp(stored_signature, signature, length)) return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
uint32_t FileHolder::fgetc32le() {
|
2016-11-21 20:47:16 +08:00
|
|
|
uint32_t result = (uint32_t)fgetc(file_);
|
|
|
|
result |= (uint32_t)(fgetc(file_) << 8);
|
|
|
|
result |= (uint32_t)(fgetc(file_) << 16);
|
|
|
|
result |= (uint32_t)(fgetc(file_) << 24);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
uint32_t FileHolder::fgetc24le() {
|
2016-11-21 20:47:16 +08:00
|
|
|
uint32_t result = (uint32_t)fgetc(file_);
|
|
|
|
result |= (uint32_t)(fgetc(file_) << 8);
|
|
|
|
result |= (uint32_t)(fgetc(file_) << 16);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
uint16_t FileHolder::fgetc16le() {
|
2016-11-21 20:47:16 +08:00
|
|
|
uint16_t result = (uint16_t)fgetc(file_);
|
|
|
|
result |= (uint16_t)(fgetc(file_) << 8);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
uint32_t FileHolder::fgetc32be() {
|
2016-11-21 20:47:16 +08:00
|
|
|
uint32_t result = (uint32_t)(fgetc(file_) << 24);
|
|
|
|
result |= (uint32_t)(fgetc(file_) << 16);
|
|
|
|
result |= (uint32_t)(fgetc(file_) << 8);
|
|
|
|
result |= (uint32_t)fgetc(file_);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
uint16_t FileHolder::fgetc16be() {
|
2016-11-21 20:47:16 +08:00
|
|
|
uint16_t result = (uint16_t)(fgetc(file_) << 8);
|
|
|
|
result |= (uint16_t)fgetc(file_);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2016-12-30 18:08:12 -05:00
|
|
|
|
2017-07-22 16:02:25 -04:00
|
|
|
void FileHolder::ensure_file_is_at_least_length(long length) {
|
2016-12-30 18:08:12 -05:00
|
|
|
fseek(file_, 0, SEEK_END);
|
|
|
|
long bytes_to_write = length - ftell(file_);
|
|
|
|
if(bytes_to_write > 0)
|
|
|
|
{
|
|
|
|
uint8_t *empty = new uint8_t[bytes_to_write];
|
2016-12-30 19:59:01 -05:00
|
|
|
memset(empty, 0, (size_t)bytes_to_write);
|
2016-12-30 18:08:12 -05:00
|
|
|
fwrite(empty, sizeof(uint8_t), (size_t)bytes_to_write, file_);
|
|
|
|
delete[] empty;
|
|
|
|
}
|
|
|
|
}
|
2017-07-22 16:02:25 -04:00
|
|
|
|
|
|
|
std::string FileHolder::extension() {
|
|
|
|
size_t pointer = name_.size() - 1;
|
|
|
|
while(pointer > 0 && name_[pointer] != '.') pointer--;
|
|
|
|
if(name_[pointer] == '.') pointer++;
|
|
|
|
|
|
|
|
std::string extension = name_.substr(pointer);
|
|
|
|
std::transform(extension.begin(), extension.end(), extension.begin(), ::tolower);
|
|
|
|
return extension;
|
|
|
|
}
|