X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fdata%2Flogic.cpp;h=3e194d54eecec4c54abaaeba1d0b7e029c755265;hp=b7b6cace08287eff88be95d951cdfbe16823f4c2;hb=ba5f21864c459a24f71ce3b0045805813c032134;hpb=8dbbc7f0b9ea59d0f0d62225772f8a56eee125f5 diff --git a/pv/data/logic.cpp b/pv/data/logic.cpp index b7b6cace..3e194d54 100644 --- a/pv/data/logic.cpp +++ b/pv/data/logic.cpp @@ -14,18 +14,18 @@ * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + * along with this program; if not, see . */ #include -#include "logic.h" -#include "logicsnapshot.h" +#include "logic.hpp" +#include "logicsegment.hpp" using std::deque; using std::max; using std::shared_ptr; +using std::vector; namespace pv { namespace data { @@ -37,36 +37,53 @@ Logic::Logic(unsigned int num_channels) : assert(num_channels_ > 0); } -int Logic::get_num_channels() const +unsigned int Logic::num_channels() const { return num_channels_; } -void Logic::push_snapshot( - shared_ptr &snapshot) +void Logic::push_segment(shared_ptr &segment) { - snapshots_.push_front(snapshot); + segments_.push_back(segment); } -deque< shared_ptr >& Logic::get_snapshots() +const deque< shared_ptr >& Logic::logic_segments() const { - return snapshots_; + return segments_; +} + +vector< shared_ptr > Logic::segments() const +{ + return vector< shared_ptr >(segments_.begin(), segments_.end()); +} + +int Logic::get_segment_count() const +{ + return segments_.size(); } void Logic::clear() { - snapshots_.clear(); + segments_.clear(); + + samples_cleared(); } -uint64_t Logic::get_max_sample_count() const +uint64_t Logic::max_sample_count() const { uint64_t l = 0; - for (std::shared_ptr s : snapshots_) { + for (shared_ptr s : segments_) { assert(s); l = max(l, s->get_sample_count()); } return l; } +void Logic::notify_samples_added(QObject* segment, uint64_t start_sample, + uint64_t end_sample) +{ + samples_added(segment, start_sample, end_sample); +} + } // namespace data } // namespace pv