diff options
author | David Robillard <d@drobilla.net> | 2011-06-07 02:44:16 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2011-06-07 02:44:16 +0000 |
commit | 00f2ad0069fe4e51e40e6a3b3d41f125b67f89cf (patch) | |
tree | 1a96d7873a700a05815bde3e3119b7055532d861 /src/AlsaDriver.hpp | |
parent | 9adc6fb021bcde9720a8afcac9a1a87521691fba (diff) | |
download | patchage-00f2ad0069fe4e51e40e6a3b3d41f125b67f89cf.tar.gz patchage-00f2ad0069fe4e51e40e6a3b3d41f125b67f89cf.tar.bz2 patchage-00f2ad0069fe4e51e40e6a3b3d41f125b67f89cf.zip |
Remove use of smart pointers in FlowCanvas entirely.
Since FlowCanvas's containers own their children, there is no real benefit to using smart pointers for objects, though there is overhead. There are no longer any add or remove methods for containers, simply create (new) and destroy (delete) objects and things should work as expected.
git-svn-id: http://svn.drobilla.net/lad/trunk/patchage@3366 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/AlsaDriver.hpp')
-rw-r--r-- | src/AlsaDriver.hpp | 35 |
1 files changed, 18 insertions, 17 deletions
diff --git a/src/AlsaDriver.hpp b/src/AlsaDriver.hpp index ab849b9..54c35b1 100644 --- a/src/AlsaDriver.hpp +++ b/src/AlsaDriver.hpp @@ -44,16 +44,17 @@ public: bool is_attached() const { return (_seq != NULL); } void refresh(); + void destroy_all(); - boost::shared_ptr<PatchagePort> create_port_view( + PatchagePort* create_port_view( Patchage* patchage, const PortID& id); - bool connect(boost::shared_ptr<PatchagePort> src_port, - boost::shared_ptr<PatchagePort> dst_port); + bool connect(PatchagePort* src_port, + PatchagePort* dst_port); - bool disconnect(boost::shared_ptr<PatchagePort> src_port, - boost::shared_ptr<PatchagePort> dst_port); + bool disconnect(PatchagePort* src_port, + PatchagePort* dst_port); void print_addr(snd_seq_addr_t addr); @@ -63,13 +64,13 @@ private: void refresh_ports(); void refresh_connections(); - void add_connections(boost::shared_ptr<PatchagePort> port); + void add_connections(PatchagePort* port); bool create_refresh_port(); static void* refresh_main(void* me); void _refresh_main(); - boost::shared_ptr<PatchageModule> + PatchageModule* find_or_create_module( Patchage* patchage, const std::string& client_name, @@ -77,16 +78,16 @@ private: void create_port_view_internal( - Patchage* patchage, - snd_seq_addr_t addr, - boost::shared_ptr<PatchageModule>& parent, - boost::shared_ptr<PatchagePort>& port); - - boost::shared_ptr<PatchagePort> create_port( - boost::shared_ptr<PatchageModule> parent, - const std::string& name, - bool is_input, - snd_seq_addr_t addr); + Patchage* patchage, + snd_seq_addr_t addr, + PatchageModule*& parent, + PatchagePort*& port); + + PatchagePort* create_port( + PatchageModule& parent, + const std::string& name, + bool is_input, + snd_seq_addr_t addr); Patchage* _app; snd_seq_t* _seq; |