2017-07-10 21:43:58 -04:00
|
|
|
//
|
|
|
|
// CSW.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 10/07/2017.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2017 Thomas Harte. All rights reserved.
|
2017-07-10 21:43:58 -04:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef CSW_hpp
|
|
|
|
#define CSW_hpp
|
|
|
|
|
|
|
|
#include "../Tape.hpp"
|
|
|
|
#include "../../FileHolder.hpp"
|
|
|
|
|
2018-04-06 17:42:24 -04:00
|
|
|
#include <string>
|
2017-07-12 21:23:59 -04:00
|
|
|
#include <vector>
|
2018-04-06 17:42:24 -04:00
|
|
|
#include <zlib.h>
|
2017-07-11 22:41:10 -04:00
|
|
|
|
2017-07-10 21:43:58 -04:00
|
|
|
namespace Storage {
|
|
|
|
namespace Tape {
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Provides a @c Tape containing a CSW tape image, which is a compressed 1-bit sampling.
|
|
|
|
*/
|
2017-11-02 22:32:00 -04:00
|
|
|
class CSW: public Tape {
|
2017-07-10 21:43:58 -04:00
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
Constructs a @c CSW containing content from the file with name @c file_name.
|
|
|
|
|
|
|
|
@throws ErrorNotCSW if this file could not be opened and recognised as a valid CSW file.
|
|
|
|
*/
|
2018-04-06 17:42:24 -04:00
|
|
|
CSW(const std::string &file_name);
|
2017-07-10 21:43:58 -04:00
|
|
|
|
2018-02-22 21:28:12 -05:00
|
|
|
enum class CompressionType {
|
|
|
|
RLE,
|
|
|
|
ZRLE
|
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Constructs a @c CSW containing content as specified. Does not throw.
|
|
|
|
*/
|
|
|
|
CSW(const std::vector<uint8_t> &&data, CompressionType compression_type, bool initial_level, uint32_t sampling_rate);
|
|
|
|
|
2017-07-10 21:43:58 -04:00
|
|
|
enum {
|
|
|
|
ErrorNotCSW
|
|
|
|
};
|
|
|
|
|
|
|
|
// implemented to satisfy @c Tape
|
|
|
|
bool is_at_end();
|
|
|
|
|
|
|
|
private:
|
|
|
|
void virtual_reset();
|
|
|
|
Pulse virtual_get_next_pulse();
|
2017-07-11 22:41:10 -04:00
|
|
|
|
|
|
|
Pulse pulse_;
|
2018-02-22 21:28:12 -05:00
|
|
|
CompressionType compression_type_;
|
2017-07-12 21:23:59 -04:00
|
|
|
|
|
|
|
uint8_t get_next_byte();
|
2017-07-13 20:57:27 -04:00
|
|
|
uint32_t get_next_int32le();
|
2017-07-12 21:23:59 -04:00
|
|
|
void invert_pulse();
|
|
|
|
|
|
|
|
std::vector<uint8_t> source_data_;
|
2017-11-11 15:28:40 -05:00
|
|
|
std::size_t source_data_pointer_;
|
2017-07-10 21:43:58 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* CSW_hpp */
|