projects
/
pulseview.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
DecodeSelector: Use custom treeview to hook into selection changes
[pulseview.git]
/
pv
/
devicemanager.hpp
diff --git
a/pv/devicemanager.hpp
b/pv/devicemanager.hpp
index 2ecf54af9aa3a84994da807806f85769769f9ff2..9b8ef3d120a3a4c68f97a9e359156270516ed4eb 100644
(file)
--- a/
pv/devicemanager.hpp
+++ b/
pv/devicemanager.hpp
@@
-14,76
+14,88
@@
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* 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 <http://www.gnu.org/licenses/>.
*/
*/
-#ifndef PULSEVIEW_PV_DEVICEMANAGER_H
-#define PULSEVIEW_PV_DEVICEMANAGER_H
+#ifndef PULSEVIEW_PV_DEVICEMANAGER_H
PP
+#define PULSEVIEW_PV_DEVICEMANAGER_H
PP
#include <list>
#include <map>
#include <memory>
#include <list>
#include <map>
#include <memory>
+#include <set>
#include <string>
#include <string>
+#include <vector>
+
+using std::list;
+using std::map;
+using std::set;
+using std::shared_ptr;
+using std::string;
+using std::vector;
namespace Glib {
namespace Glib {
-
class VariantBase;
+class VariantBase;
}
namespace sigrok {
}
namespace sigrok {
- class ConfigKey;
- class Context;
- class Driver;
- class Device;
- class HardwareDevice;
+class ConfigKey;
+class Context;
+class Driver;
}
}
+using sigrok::ConfigKey;
+
namespace pv {
namespace pv {
+namespace devices {
+class Device;
+class HardwareDevice;
+}
+
class Session;
class DeviceManager
{
public:
class Session;
class DeviceManager
{
public:
- DeviceManager(std::shared_ptr<sigrok::Context> context);
+ DeviceManager(shared_ptr<sigrok::Context> context,
+ std::string driver, bool do_scan);
- ~DeviceManager();
+ ~DeviceManager()
= default
;
-
std::shared_ptr<sigrok::Context> context()
;
+
const shared_ptr<sigrok::Context>& context() const
;
- const std::list< std::shared_ptr<sigrok::HardwareDevice> >&
- devices() const;
+ shared_ptr<sigrok::Context> context();
- std::list< std::shared_ptr<sigrok::HardwareDevice> > driver_scan(
- std::shared_ptr<sigrok::Driver> driver,
- std::map<const sigrok::ConfigKey *, Glib::VariantBase> drvopts);
+ const list< shared_ptr<devices::HardwareDevice> >& devices() const;
+ shared_ptr<devices::HardwareDevice> user_spec_device() const;
- const std::map<std::string, std::string> get_device_info(
- const std::shared_ptr<sigrok::Device> device);
+ bool driver_supported(shared_ptr<sigrok::Driver> driver) const;
- const std::shared_ptr<sigrok::HardwareDevice> find_device_from_info(
- const std::map<std::string, std::string> search_info);
+ list< shared_ptr<devices::HardwareDevice> > driver_scan(
+ shared_ptr<sigrok::Driver> driver,
+ map<const sigrok::ConfigKey *, Glib::VariantBase> drvopts);
- void build_display_name(std::shared_ptr<sigrok::Device> device);
+ const map<string, string> get_device_info(
+ const shared_ptr<devices::Device> device);
- const std::string get_display_name(std::shared_ptr<sigrok::Device> dev);
-
- const std::string get_full_name(std::shared_ptr<sigrok::Device> dev);
-
- void update_display_name(std::shared_ptr<sigrok::Device> dev);
+ const shared_ptr<devices::HardwareDevice> find_device_from_info(
+ const map<string, string> search_info);
private:
private:
- bool compare_devices(s
td::shared_ptr<sigrok
::Device> a,
- s
td::shared_ptr<sigrok
::Device> b);
+ bool compare_devices(s
hared_ptr<devices
::Device> a,
+ s
hared_ptr<devices
::Device> b);
-protected:
- std::shared_ptr<sigrok::Context> context_;
-
std::list< std::shared_ptr<sigrok::HardwareDevice> > devices_
;
+ static map<const ConfigKey *, Glib::VariantBase>
+ drive_scan_options(vector<string> user_spec,
+
set<const ConfigKey *> driver_opts)
;
- std::map< std::shared_ptr<sigrok::Device>, std::string > display_names_;
- std::map< std::shared_ptr<sigrok::Device>, std::string > full_names_;
+protected:
+ shared_ptr<sigrok::Context> context_;
+ list< shared_ptr<devices::HardwareDevice> > devices_;
+ shared_ptr<devices::HardwareDevice> user_spec_device_;
};
} // namespace pv
};
} // namespace pv
-#endif // PULSEVIEW_PV_DEVICEMANAGER_H
+#endif // PULSEVIEW_PV_DEVICEMANAGER_H
PP