X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=trace_file.hpp;h=2129d1e388f197b9e2cd7e844ddcf836b3e4cbdc;hb=f562f318ddee6da2041696887e2195fc3c96d740;hp=7e7f9bd09bf5ff3ac473952796aaf9e20c884cc0;hpb=bb130e5395d472c8ce23012c8234b32ca38fa460;p=apitrace diff --git a/trace_file.hpp b/trace_file.hpp index 7e7f9bd..2129d1e 100644 --- a/trace_file.hpp +++ b/trace_file.hpp @@ -1,8 +1,35 @@ +/************************************************************************** + * + * Copyright 2011 Zack Rusin + * All Rights Reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + * + **************************************************************************/ + + #ifndef TRACE_FILE_HPP #define TRACE_FILE_HPP #include #include +#include namespace Trace { @@ -12,6 +39,18 @@ public: Read, Write }; + struct Offset { + Offset() + : chunk(0), + offsetInChunk(0) + {} + uint64_t chunk; + uint32_t offsetInChunk; + }; + +public: + static bool isZLibCompressed(const std::string &filename); + static bool isSnappyCompressed(const std::string &filename); public: File(const std::string &filename = std::string(), File::Mode mode = File::Read); @@ -19,15 +58,19 @@ public: bool isOpened() const; File::Mode mode() const; + std::string filename() const; bool open(const std::string &filename, File::Mode mode); bool write(const void *buffer, int length); bool read(void *buffer, int length); void close(); - void flush(); + void flush(void); int getc(); + virtual bool supportsOffsets() const = 0; + virtual File::Offset currentOffset(); + virtual void setCurrentOffset(const File::Offset &offset); protected: virtual bool rawOpen(const std::string &filename, File::Mode mode) = 0; virtual bool rawWrite(const void *buffer, int length) = 0; @@ -42,12 +85,77 @@ protected: bool m_isOpened; }; +inline bool File::isOpened() const +{ + return m_isOpened; +} + +inline File::Mode File::mode() const +{ + return m_mode; +} + +inline std::string File::filename() const +{ + return m_filename; +} + +inline bool File::open(const std::string &filename, File::Mode mode) +{ + if (m_isOpened) { + close(); + } + m_isOpened = rawOpen(filename, mode); + m_mode = mode; + + return m_isOpened; +} + +inline bool File::write(const void *buffer, int length) +{ + if (!m_isOpened || m_mode != File::Write) { + return false; + } + return rawWrite(buffer, length); +} + +inline bool File::read(void *buffer, int length) +{ + if (!m_isOpened || m_mode != File::Read) { + return false; + } + return rawRead(buffer, length); +} + +inline void File::close() +{ + if (m_isOpened) { + rawClose(); + m_isOpened = false; + } +} + +inline void File::flush(void) +{ + rawFlush(); +} + +inline int File::getc() +{ + if (!m_isOpened || m_mode != File::Read) { + return -1; + } + return rawGetc(); +} + class ZLibFile : public File { public: ZLibFile(const std::string &filename = std::string(), File::Mode mode = File::Read); virtual ~ZLibFile(); + + virtual bool supportsOffsets() const; protected: virtual bool rawOpen(const std::string &filename, File::Mode mode); virtual bool rawWrite(const void *buffer, int length); @@ -59,43 +167,38 @@ private: void *m_gzFile; }; -namespace snappy { - class File; +inline bool +operator<(const File::Offset &one, const File::Offset &two) +{ + return one.chunk < two.chunk || + (one.chunk == two.chunk && one.offsetInChunk < two.offsetInChunk); } -#define SNAPPY_CHUNK_SIZE (1 * 1024 * 1024) -class SnappyFile : public File { -public: - SnappyFile(const std::string &filename = std::string(), - File::Mode mode = File::Read); - virtual ~SnappyFile(); +inline bool +operator==(const File::Offset &one, const File::Offset &two) +{ + return one.chunk == two.chunk && + one.offsetInChunk == two.offsetInChunk; +} -protected: - virtual bool rawOpen(const std::string &filename, File::Mode mode); - virtual bool rawWrite(const void *buffer, int length); - virtual bool rawRead(void *buffer, int length); - virtual int rawGetc(); - virtual void rawClose(); - virtual void rawFlush(); +inline bool +operator>=(const File::Offset &one, const File::Offset &two) +{ + return one.chunk > two.chunk || + (one.chunk == two.chunk && one.offsetInChunk >= two.offsetInChunk); +} -private: - inline int freeCacheSize() const - { - if (m_cacheSize > 0) - return m_cacheSize - (m_cachePtr - m_cache); - else - return 0; - } - void flushCache(); - void createCache(size_t size); -private: - std::fstream m_stream; - char *m_cache; - char *m_cachePtr; - size_t m_cacheSize; +inline bool +operator>(const File::Offset &one, const File::Offset &two) +{ + return two < one; +} - char *m_compressedCache; -}; +inline bool +operator<=(const File::Offset &one, const File::Offset &two) +{ + return two >= one; +} }