2016-07-10 18:36:52 -04:00
|
|
|
//
|
|
|
|
// PCMTrack.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 10/07/2016.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2016 Thomas Harte. All rights reserved.
|
2016-07-10 18:36:52 -04:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef PCMTrack_hpp
|
|
|
|
#define PCMTrack_hpp
|
|
|
|
|
2017-09-22 22:39:23 -04:00
|
|
|
#include "Track.hpp"
|
2016-12-17 21:13:57 -05:00
|
|
|
#include "PCMSegment.hpp"
|
2018-06-30 20:03:18 -04:00
|
|
|
#include "../../../ClockReceiver/ClockReceiver.hpp"
|
|
|
|
|
2016-07-10 18:36:52 -04:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace Storage {
|
2016-08-27 17:15:09 -04:00
|
|
|
namespace Disk {
|
2016-07-10 18:36:52 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
A subclass of @c Track that provides its @c Events by querying a pulse-code modulated record of original
|
|
|
|
flux detections, with an implied index hole at the very start of the data.
|
|
|
|
|
|
|
|
The data may consist of a single @c PCMSegment or of multiple, allowing a PCM-format track to contain
|
|
|
|
multiple distinct segments of data, each with a separate clock rate.
|
|
|
|
*/
|
|
|
|
class PCMTrack: public Track {
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
Creates a @c PCMTrack consisting of multiple segments of data, permitting multiple clock rates.
|
|
|
|
*/
|
2016-12-30 14:23:26 -05:00
|
|
|
PCMTrack(const std::vector<PCMSegment> &);
|
2016-07-10 18:36:52 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
Creates a @c PCMTrack consisting of a single continuous run of data, implying a constant clock rate.
|
2016-08-01 08:41:16 -04:00
|
|
|
The segment's @c length_of_a_bit will be ignored and therefore need not be filled in.
|
2016-07-10 18:36:52 -04:00
|
|
|
*/
|
2016-12-30 14:23:26 -05:00
|
|
|
PCMTrack(const PCMSegment &);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Copy constructor; required for Tracks in order to support modifiable disks.
|
|
|
|
*/
|
|
|
|
PCMTrack(const PCMTrack &);
|
2016-07-10 18:36:52 -04:00
|
|
|
|
2018-07-01 22:49:57 -04:00
|
|
|
/*!
|
|
|
|
Creates a PCMTrack by sampling the original at a rate of @c bits_per_track.
|
|
|
|
*/
|
|
|
|
static PCMTrack *resampled_clone(Track *original, size_t bits_per_track);
|
|
|
|
|
2016-07-10 18:36:52 -04:00
|
|
|
// as per @c Track
|
2020-01-23 22:57:51 -05:00
|
|
|
Event get_next_event() final;
|
|
|
|
Time seek_to(const Time &time_since_index_hole) final;
|
|
|
|
Track *clone() const final;
|
2016-07-10 18:36:52 -04:00
|
|
|
|
2018-06-30 20:03:18 -04:00
|
|
|
// Obtains a copy of this track, flattened to a single PCMSegment, which
|
|
|
|
// consists of @c bits_per_track potential flux transition points.
|
2018-07-01 22:49:57 -04:00
|
|
|
PCMTrack *resampled_clone(size_t bits_per_track);
|
|
|
|
bool is_resampled_clone();
|
2018-06-30 20:03:18 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
Replaces whatever is currently on the track from @c start_position to @c start_position + segment length
|
|
|
|
with the contents of @c segment.
|
|
|
|
|
|
|
|
This is a well-defined operation only for tracks with a single segment. The new segment will be resampled
|
|
|
|
to the track's underlying segment, which will be mutated.
|
|
|
|
|
|
|
|
@param start_time The time at which this segment begins. Must be in the range [0, 1).
|
|
|
|
@param segment The PCM segment to add.
|
|
|
|
@param clamp_to_index_hole If @c true then the new segment will be truncated if it overruns the index hole;
|
|
|
|
it will otherwise write over the index hole and continue.
|
|
|
|
*/
|
|
|
|
void add_segment(const Time &start_time, const PCMSegment &segment, bool clamp_to_index_hole);
|
|
|
|
|
2016-07-10 18:36:52 -04:00
|
|
|
private:
|
2018-06-30 20:03:18 -04:00
|
|
|
/*!
|
|
|
|
Creates a PCMTrack with a single segment, consisting of @c bits_per_track flux windows,
|
|
|
|
initialised with no flux events.
|
|
|
|
*/
|
|
|
|
PCMTrack(unsigned int bits_per_track);
|
|
|
|
|
2016-07-10 18:36:52 -04:00
|
|
|
// storage for the segments that describe this track
|
2016-12-18 21:37:05 -05:00
|
|
|
std::vector<PCMSegmentEventSource> segment_event_sources_;
|
2016-07-10 18:36:52 -04:00
|
|
|
|
|
|
|
// a pointer to the first bit to consider as the next event
|
2017-11-11 15:28:40 -05:00
|
|
|
std::size_t segment_pointer_;
|
2016-12-18 21:37:05 -05:00
|
|
|
|
|
|
|
PCMTrack();
|
2018-07-01 22:49:57 -04:00
|
|
|
bool is_resampled_clone_ = false;
|
2016-07-10 18:36:52 -04:00
|
|
|
};
|
|
|
|
|
2016-08-27 17:15:09 -04:00
|
|
|
}
|
2016-07-10 18:36:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* PCMTrack_hpp */
|