2017-07-16 22:04:40 -04:00
|
|
|
//
|
|
|
|
// PulseQueuedTape.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 16/07/2017.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2017 Thomas Harte. All rights reserved.
|
2017-07-16 22:04:40 -04:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef PulseQueuedTape_hpp
|
|
|
|
#define PulseQueuedTape_hpp
|
|
|
|
|
|
|
|
#include "Tape.hpp"
|
|
|
|
#include <vector>
|
|
|
|
|
2023-05-10 16:02:18 -05:00
|
|
|
namespace Storage::Tape {
|
2017-07-16 22:04:40 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
Provides a @c Tape with a queue of upcoming pulses and an is-at-end flag.
|
|
|
|
|
|
|
|
If is-at-end is set then get_next_pulse() returns a second of silence and
|
|
|
|
is_at_end() returns true.
|
2017-11-07 22:51:06 -05:00
|
|
|
|
2017-07-16 22:04:40 -04:00
|
|
|
Otherwise get_next_pulse() returns something from the pulse queue if there is
|
|
|
|
anything there, and otherwise calls get_next_pulses(). get_next_pulses() is
|
|
|
|
virtual, giving subclasses a chance to provide the next batch of pulses.
|
|
|
|
*/
|
|
|
|
class PulseQueuedTape: public Tape {
|
|
|
|
public:
|
|
|
|
PulseQueuedTape();
|
|
|
|
bool is_at_end();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void emplace_back(Tape::Pulse::Type type, Time length);
|
2018-02-22 21:28:12 -05:00
|
|
|
void emplace_back(const Tape::Pulse &&pulse);
|
2017-07-16 22:04:40 -04:00
|
|
|
void clear();
|
|
|
|
bool empty();
|
|
|
|
|
|
|
|
void set_is_at_end(bool);
|
|
|
|
virtual void get_next_pulses() = 0;
|
|
|
|
|
|
|
|
private:
|
|
|
|
Pulse virtual_get_next_pulse();
|
|
|
|
Pulse silence();
|
|
|
|
|
|
|
|
std::vector<Pulse> queued_pulses_;
|
2017-11-11 15:28:40 -05:00
|
|
|
std::size_t pulse_pointer_;
|
2017-07-16 22:04:40 -04:00
|
|
|
bool is_at_end_;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* PulseQueuedTape_hpp */
|