|
rpm-build |
d2b433 |
/* -*- Mode: C++; c-basic-offset:4; tab-width:4; indent-tabs-mode:nil -*- */
|
|
rpm-build |
d2b433 |
/*
|
|
rpm-build |
d2b433 |
* libopenraw - rawcontainer.cpp
|
|
rpm-build |
d2b433 |
*
|
|
rpm-build |
d2b433 |
* Copyright (C) 2006-2017 Hubert Figuière
|
|
rpm-build |
d2b433 |
*
|
|
rpm-build |
d2b433 |
* This library is free software: you can redistribute it and/or
|
|
rpm-build |
d2b433 |
* modify it under the terms of the GNU Lesser General Public License
|
|
rpm-build |
d2b433 |
* as published by the Free Software Foundation, either version 3 of
|
|
rpm-build |
d2b433 |
* the License, or (at your option) any later version.
|
|
rpm-build |
d2b433 |
*
|
|
rpm-build |
d2b433 |
* This library is distributed in the hope that it will be useful,
|
|
rpm-build |
d2b433 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
rpm-build |
d2b433 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
rpm-build |
d2b433 |
* Lesser General Public License for more details.
|
|
rpm-build |
d2b433 |
*
|
|
rpm-build |
d2b433 |
* You should have received a copy of the GNU Lesser General Public
|
|
rpm-build |
d2b433 |
* License along with this library. If not, see
|
|
rpm-build |
d2b433 |
* <http://www.gnu.org/licenses/>.
|
|
rpm-build |
d2b433 |
*/
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
#include <fcntl.h>
|
|
rpm-build |
d2b433 |
#include <memory>
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
#include <libopenraw/debug.h>
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
#include "trace.hpp"
|
|
rpm-build |
d2b433 |
#include "endianutils.hpp"
|
|
rpm-build |
d2b433 |
#include "rawcontainer.hpp"
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
using namespace Debug;
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
namespace OpenRaw {
|
|
rpm-build |
d2b433 |
namespace Internals {
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
RawContainer::RawContainer(const IO::Stream::Ptr &_file, off_t _offset)
|
|
rpm-build |
d2b433 |
: m_file(_file),
|
|
rpm-build |
d2b433 |
m_offset(_offset),
|
|
rpm-build |
d2b433 |
m_endian(ENDIAN_NULL)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
m_file->open();
|
|
rpm-build |
d2b433 |
m_file->seek(_offset, SEEK_SET);
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
RawContainer::~RawContainer()
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
m_file->close();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
bool RawContainer::skip(off_t offset)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
m_file->seek(offset, SEEK_CUR);
|
|
rpm-build |
d2b433 |
return true;
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
Option<int8_t>
|
|
rpm-build |
d2b433 |
RawContainer::readInt8(const IO::Stream::Ptr &f)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
unsigned char buf;
|
|
rpm-build |
d2b433 |
int s = f->read(&buf, 1);
|
|
rpm-build |
d2b433 |
if (s != 1) {
|
|
rpm-build |
d2b433 |
return Option<int8_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
return Option<int8_t>(buf);
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
Option<uint8_t>
|
|
rpm-build |
d2b433 |
RawContainer::readUInt8(const IO::Stream::Ptr &f)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
unsigned char buf;
|
|
rpm-build |
d2b433 |
int s = f->read(&buf, 1);
|
|
rpm-build |
d2b433 |
if (s != 1) {
|
|
rpm-build |
d2b433 |
return Option<uint8_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
return Option<uint8_t>(buf);
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
Option<int16_t>
|
|
rpm-build |
d2b433 |
RawContainer::readInt16(const IO::Stream::Ptr &f)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_NULL) {
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
LOGERR("null endian\n");
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
return Option<int16_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
unsigned char buf[2];
|
|
rpm-build |
d2b433 |
int s = f->read(buf, 2);
|
|
rpm-build |
d2b433 |
if (s != 2) {
|
|
rpm-build |
d2b433 |
return Option<int16_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_LITTLE) {
|
|
rpm-build |
d2b433 |
return Option<int16_t>(EL16(buf));
|
|
rpm-build |
d2b433 |
} else {
|
|
rpm-build |
d2b433 |
return Option<int16_t>(BE16(buf));
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
/**
|
|
rpm-build |
d2b433 |
* Return the number of element read.
|
|
rpm-build |
d2b433 |
*/
|
|
rpm-build |
d2b433 |
size_t
|
|
rpm-build |
d2b433 |
RawContainer::readUInt16Array(const IO::Stream::Ptr &f, std::vector<uint16_t> & v, size_t count)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_NULL) {
|
|
rpm-build |
d2b433 |
LOGERR("null endian\n");
|
|
rpm-build |
d2b433 |
return 0;
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
if (v.size() < count) {
|
|
rpm-build |
d2b433 |
v.resize(count, 0);
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
uint8_t buf[2];
|
|
rpm-build |
d2b433 |
size_t num_read = 0;
|
|
rpm-build |
d2b433 |
for (size_t i = 0; i < count; i++) {
|
|
rpm-build |
d2b433 |
int s = f->read(buf, 2);
|
|
rpm-build |
d2b433 |
uint16_t val;
|
|
rpm-build |
d2b433 |
if (s != 2) {
|
|
rpm-build |
d2b433 |
return num_read;
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_LITTLE) {
|
|
rpm-build |
d2b433 |
val = EL16(buf);
|
|
rpm-build |
d2b433 |
} else {
|
|
rpm-build |
d2b433 |
val = BE16(buf);
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
v[i] = val;
|
|
rpm-build |
d2b433 |
num_read++;
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
return num_read;
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
Option<int32_t>
|
|
rpm-build |
d2b433 |
RawContainer::readInt32(const IO::Stream::Ptr &f)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_NULL) {
|
|
rpm-build |
d2b433 |
LOGERR("null endian\n");
|
|
rpm-build |
d2b433 |
return Option<int32_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
unsigned char buf[4];
|
|
rpm-build |
d2b433 |
int s = f->read(buf, 4);
|
|
rpm-build |
d2b433 |
if (s != 4) {
|
|
rpm-build |
d2b433 |
LOGERR("read %d bytes\n", s);
|
|
rpm-build |
d2b433 |
return Option<int32_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_LITTLE) {
|
|
rpm-build |
d2b433 |
return Option<int32_t>(EL32(buf));
|
|
rpm-build |
d2b433 |
} else {
|
|
rpm-build |
d2b433 |
return Option<int32_t>(BE32(buf));
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
Option<uint16_t>
|
|
rpm-build |
d2b433 |
RawContainer::readUInt16(const IO::Stream::Ptr &f)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_NULL) {
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
LOGERR("null endian\n");
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
return Option<uint16_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
unsigned char buf[2];
|
|
rpm-build |
d2b433 |
int s = f->read(buf, 2);
|
|
rpm-build |
d2b433 |
if (s != 2) {
|
|
rpm-build |
d2b433 |
return Option<uint16_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_LITTLE) {
|
|
rpm-build |
d2b433 |
return Option<uint16_t>(EL16(buf));
|
|
rpm-build |
d2b433 |
} else {
|
|
rpm-build |
d2b433 |
return Option<uint16_t>(BE16(buf));
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
Option<uint32_t>
|
|
rpm-build |
d2b433 |
RawContainer::readUInt32(const IO::Stream::Ptr &f)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_NULL) {
|
|
rpm-build |
d2b433 |
LOGERR("null endian\n");
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
return Option<uint32_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
unsigned char buf[4];
|
|
rpm-build |
d2b433 |
int s = f->read(buf, 4);
|
|
rpm-build |
d2b433 |
if (s != 4) {
|
|
rpm-build |
d2b433 |
return Option<uint32_t>();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
if (m_endian == ENDIAN_LITTLE) {
|
|
rpm-build |
d2b433 |
return Option<uint32_t>(EL32(buf));
|
|
rpm-build |
d2b433 |
} else {
|
|
rpm-build |
d2b433 |
return Option<uint32_t>(BE32(buf));
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
size_t
|
|
rpm-build |
d2b433 |
RawContainer::fetchData(void *buf, off_t _offset,
|
|
rpm-build |
d2b433 |
size_t buf_size)
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
size_t s = 0;
|
|
rpm-build |
d2b433 |
m_file->seek(_offset, SEEK_SET);
|
|
rpm-build |
d2b433 |
s = m_file->read(buf, buf_size);
|
|
rpm-build |
d2b433 |
return s;
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
off_t
|
|
rpm-build |
d2b433 |
RawContainer::size() const
|
|
rpm-build |
d2b433 |
{
|
|
rpm-build |
d2b433 |
return m_file->filesize();
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
}
|
|
rpm-build |
d2b433 |
/*
|
|
rpm-build |
d2b433 |
Local Variables:
|
|
rpm-build |
d2b433 |
mode:c++
|
|
rpm-build |
d2b433 |
c-file-style:"stroustrup"
|
|
rpm-build |
d2b433 |
c-file-offsets:((innamespace . 0))
|
|
rpm-build |
d2b433 |
tab-width:2
|
|
rpm-build |
d2b433 |
c-basic-offset:2
|
|
rpm-build |
d2b433 |
indent-tabs-mode:nil
|
|
rpm-build |
d2b433 |
fill-column:80
|
|
rpm-build |
d2b433 |
End:
|
|
rpm-build |
d2b433 |
*/
|