X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fsession.hpp;h=ead2f82df47955773e53a562f91c18a3e75f94d6;hb=ba0c5f899c654a22506adb799f23f718421bf453;hp=0828edbbf912cb3d8e09e18db94102df872ca1e1;hpb=bf9146988d2298e1750142dccdcf597ef13d6606;p=pulseview.git
diff --git a/pv/session.hpp b/pv/session.hpp
index 0828edb..ead2f82 100644
--- a/pv/session.hpp
+++ b/pv/session.hpp
@@ -14,8 +14,7 @@
* 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 .
*/
#ifndef PULSEVIEW_PV_SESSION_HPP
@@ -30,16 +29,22 @@
#include
#include
-#ifdef _WIN32
-// Windows: Avoid namespace pollution by thread.hpp (which includes windows.h).
-#define NOGDI
-#define NORESOURCE
-#endif
-#include
-
#include
+#include
#include
+#include "util.hpp"
+#include "views/viewbase.hpp"
+
+using std::function;
+using std::list;
+using std::map;
+using std::mutex;
+using std::recursive_mutex;
+using std::shared_ptr;
+using std::string;
+using std::unordered_set;
+
struct srd_decoder;
struct srd_channel;
@@ -47,11 +52,16 @@ namespace sigrok {
class Analog;
class Channel;
class Device;
+class InputFormat;
class Logic;
class Meta;
+class Option;
+class OutputFormat;
class Packet;
class Session;
-}
+} // namespace sigrok
+
+using sigrok::Option;
namespace pv {
@@ -60,8 +70,10 @@ class DeviceManager;
namespace data {
class Analog;
class AnalogSegment;
+class DecodeSignal;
class Logic;
class LogicSegment;
+class SignalBase;
class SignalData;
}
@@ -69,10 +81,12 @@ namespace devices {
class Device;
}
-namespace view {
-class DecodeTrace;
-class LogicSignal;
-class Signal;
+namespace toolbars {
+class MainBar;
+}
+
+namespace views {
+class ViewBase;
}
class Session : public QObject
@@ -86,8 +100,10 @@ public:
Running
};
+ static shared_ptr sr_context;
+
public:
- Session(DeviceManager &device_manager);
+ Session(DeviceManager &device_manager, QString name);
~Session();
@@ -95,35 +111,74 @@ public:
const DeviceManager& device_manager() const;
- std::shared_ptr session() const;
+ shared_ptr session() const;
+
+ shared_ptr device() const;
+
+ QString name() const;
+
+ void set_name(QString name);
+
+ const list< shared_ptr > views() const;
+
+ shared_ptr main_view() const;
+
+ shared_ptr main_bar() const;
+
+ void set_main_bar(shared_ptr main_bar);
+
+ /**
+ * Indicates whether the captured data was saved to disk already or not
+ */
+ bool data_saved() const;
+
+ void save_settings(QSettings &settings) const;
- std::shared_ptr device() const;
+ void restore_settings(QSettings &settings);
+
+ /**
+ * Attempts to set device instance, may fall back to demo if needed
+ */
+ void select_device(shared_ptr device);
/**
* Sets device instance that will be used in the next capture session.
*/
- void set_device(std::shared_ptr device);
+ void set_device(shared_ptr device);
void set_default_device();
+ void load_init_file(const string &file_name, const string &format);
+
+ void load_file(QString file_name,
+ shared_ptr format = nullptr,
+ const map &options =
+ map());
+
capture_state get_capture_state() const;
- void start_capture(std::function error_handler);
+ void start_capture(function error_handler);
void stop_capture();
- std::set< std::shared_ptr > get_data() const;
+ double get_samplerate() const;
- const std::unordered_set< std::shared_ptr >
- signals() const;
+ uint32_t get_segment_count() const;
-#ifdef ENABLE_DECODE
- bool add_decoder(srd_decoder *const dec);
+ void register_view(shared_ptr view);
+
+ void deregister_view(shared_ptr view);
+
+ bool has_view(shared_ptr view);
- std::vector< std::shared_ptr >
- get_decode_signals() const;
+ const unordered_set< shared_ptr > signalbases() const;
- void remove_decode_signal(view::DecodeTrace *signal);
+ bool all_segments_complete(uint32_t segment_id) const;
+
+#ifdef ENABLE_DECODE
+ shared_ptr add_decode_signal();
+
+ void remove_decode_signal(shared_ptr signal);
#endif
private:
@@ -131,60 +186,87 @@ private:
void update_signals();
- std::shared_ptr signal_from_channel(
- std::shared_ptr channel) const;
+ shared_ptr signalbase_from_channel(
+ shared_ptr channel) const;
+
+ static map input_format_options(
+ vector user_spec,
+ map> fmt_opts);
private:
- void sample_thread_proc(std::shared_ptr device,
- std::function error_handler);
+ void sample_thread_proc(function error_handler);
+
+ void free_unused_memory();
+
+ void signal_new_segment();
+ void signal_segment_completed();
void feed_in_header();
- void feed_in_meta(std::shared_ptr meta);
+ void feed_in_meta(shared_ptr meta);
+
+ void feed_in_trigger();
void feed_in_frame_begin();
+ void feed_in_frame_end();
- void feed_in_logic(std::shared_ptr logic);
+ void feed_in_logic(shared_ptr logic);
- void feed_in_analog(std::shared_ptr analog);
+ void feed_in_analog(shared_ptr analog);
- void data_feed_in(std::shared_ptr device,
- std::shared_ptr packet);
+ void data_feed_in(shared_ptr device,
+ shared_ptr packet);
private:
DeviceManager &device_manager_;
- std::shared_ptr device_;
+ shared_ptr device_;
+ QString default_name_, name_;
- std::vector< std::shared_ptr > decode_traces_;
+ list< shared_ptr > views_;
+ shared_ptr main_view_;
- mutable std::mutex sampling_mutex_;
+ shared_ptr main_bar_;
+
+ mutable mutex sampling_mutex_; //!< Protects access to capture_state_.
capture_state capture_state_;
- mutable boost::shared_mutex signals_mutex_;
- std::unordered_set< std::shared_ptr > signals_;
+ unordered_set< shared_ptr > signalbases_;
+ unordered_set< shared_ptr > all_signal_data_;
- mutable std::recursive_mutex data_mutex_;
- std::shared_ptr logic_data_;
+ mutable recursive_mutex data_mutex_;
+ shared_ptr logic_data_;
uint64_t cur_samplerate_;
- std::shared_ptr cur_logic_segment_;
- std::map< std::shared_ptr, std::shared_ptr >
+ shared_ptr cur_logic_segment_;
+ map< shared_ptr, shared_ptr >
cur_analog_segments_;
+ int32_t highest_segment_id_;
std::thread sampling_thread_;
bool out_of_memory_;
+ bool data_saved_;
+ bool frame_began_;
Q_SIGNALS:
void capture_state_changed(int state);
- void device_selected();
+ void device_changed();
void signals_changed();
- void frame_began();
+ void name_changed();
+
+ void trigger_event(util::Timestamp location);
+
+ void new_segment(int new_segment_id);
+ void segment_completed(int segment_id);
void data_received();
- void frame_ended();
+ void add_view(const QString &title, views::ViewType type,
+ Session *session);
+
+public Q_SLOTS:
+ void on_data_saved();
};
} // namespace pv