From c35cbf038d0992887b8d4bcf5d4ff83c323ec60c Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sun, 8 Dec 2019 18:03:43 +0100 Subject: Cleanup: Avoid parameter copying overhead --- ingen/EngineBase.hpp | 4 ++-- ingen/LV2Features.hpp | 2 +- ingen/Parser.hpp | 26 +++++++++++++------------- ingen/Serialiser.hpp | 12 ++++++------ ingen/Store.hpp | 2 +- ingen/TurtleWriter.hpp | 2 +- ingen/World.hpp | 10 +++++----- ingen/client/BlockModel.hpp | 36 +++++++++++++++++++----------------- ingen/client/GraphModel.hpp | 8 ++++---- ingen/client/ObjectModel.hpp | 8 ++++---- ingen/client/PortModel.hpp | 6 +++--- 11 files changed, 59 insertions(+), 57 deletions(-) (limited to 'ingen') diff --git a/ingen/EngineBase.hpp b/ingen/EngineBase.hpp index 7b3239f1..36742601 100644 --- a/ingen/EngineBase.hpp +++ b/ingen/EngineBase.hpp @@ -132,12 +132,12 @@ public: /** Register a client to receive updates about engine changes. */ - virtual void register_client(SPtr client) = 0; + virtual void register_client(const SPtr& client) = 0; /** Unregister a client. */ - virtual bool unregister_client(SPtr client) = 0; + virtual bool unregister_client(const SPtr& client) = 0; }; } // namespace ingen diff --git a/ingen/LV2Features.hpp b/ingen/LV2Features.hpp index e2ce600f..06811294 100644 --- a/ingen/LV2Features.hpp +++ b/ingen/LV2Features.hpp @@ -78,7 +78,7 @@ protected: LV2_Feature** _array; }; - void add_feature(SPtr feature); + void add_feature(const SPtr& feature); bool is_supported(const std::string& uri) const; SPtr lv2_features(World& world, Node* node) const; diff --git a/ingen/Parser.hpp b/ingen/Parser.hpp index 8d868a8c..45d087cd 100644 --- a/ingen/Parser.hpp +++ b/ingen/Parser.hpp @@ -77,21 +77,21 @@ public: * @return whether or not load was successful. */ virtual bool parse_file( - World& world, - Interface& target, - const FilePath& path, - boost::optional parent = boost::optional(), - boost::optional symbol = boost::optional(), - boost::optional data = boost::optional()); + World& world, + Interface& target, + const FilePath& path, + const boost::optional& parent = boost::optional(), + const boost::optional& symbol = boost::optional(), + const boost::optional& data = boost::optional()); virtual boost::optional parse_string( - World& world, - Interface& target, - const std::string& str, - const URI& base_uri, - boost::optional parent = boost::optional(), - boost::optional symbol = boost::optional(), - boost::optional data = boost::optional()); + World& world, + Interface& target, + const std::string& str, + const URI& base_uri, + const boost::optional& parent = boost::optional(), + const boost::optional& symbol = boost::optional(), + const boost::optional& data = boost::optional()); }; } // namespace ingen diff --git a/ingen/Serialiser.hpp b/ingen/Serialiser.hpp index 4980a36d..776b837e 100644 --- a/ingen/Serialiser.hpp +++ b/ingen/Serialiser.hpp @@ -46,8 +46,8 @@ public: virtual ~Serialiser(); /** Write a graph and all its contents as a complete bundle. */ - virtual void write_bundle(SPtr graph, - const URI& uri); + virtual void write_bundle(const SPtr& graph, + const URI& uri); /** Begin a serialization to a string. * @@ -76,15 +76,15 @@ public: * * @throw std::logic_error */ - virtual void serialise(SPtr object, - Property::Graph context = Property::Graph::DEFAULT); + virtual void serialise(const SPtr& object, + Property::Graph context = Property::Graph::DEFAULT); /** Serialize an arc. * * @throw std::logic_error */ - virtual void serialise_arc(const Sord::Node& parent, - SPtr arc); + virtual void serialise_arc(const Sord::Node& parent, + const SPtr& arc); /** Finish serialization. * diff --git a/ingen/Store.hpp b/ingen/Store.hpp index 3c92dcc4..1aa90936 100644 --- a/ingen/Store.hpp +++ b/ingen/Store.hpp @@ -54,7 +54,7 @@ public: iterator find_descendants_end(Store::iterator parent); const_iterator find_descendants_end(Store::const_iterator parent) const; - const_range children_range(SPtr o) const; + const_range children_range(const SPtr& o) const; /** Remove the object at `top` and all its children from the store. * diff --git a/ingen/TurtleWriter.hpp b/ingen/TurtleWriter.hpp index 2ee027ae..9c88be2e 100644 --- a/ingen/TurtleWriter.hpp +++ b/ingen/TurtleWriter.hpp @@ -41,7 +41,7 @@ class URIs; class INGEN_API TurtleWriter : public AtomWriter, public AtomSink { public: - TurtleWriter(URIMap& map, URIs& uris, const URI& uri); + TurtleWriter(URIMap& map, URIs& uris, URI uri); ~TurtleWriter() override; diff --git a/ingen/World.hpp b/ingen/World.hpp index c8d69c5b..a2906525 100644 --- a/ingen/World.hpp +++ b/ingen/World.hpp @@ -102,16 +102,16 @@ public: * @param respondee The Interface that will receive responses to commands * and broadcasts, if applicable. */ - virtual SPtr new_interface(const URI& engine_uri, - SPtr respondee); + virtual SPtr new_interface(const URI& engine_uri, + const SPtr& respondee); /** Run a script. */ virtual bool run(const std::string& mime_type, const std::string& filename); - virtual void set_engine(SPtr e); - virtual void set_interface(SPtr i); - virtual void set_store(SPtr s); + virtual void set_engine(const SPtr& e); + virtual void set_interface(const SPtr& i); + virtual void set_store(const SPtr& s); virtual SPtr engine(); virtual SPtr interface(); diff --git a/ingen/client/BlockModel.hpp b/ingen/client/BlockModel.hpp index f6aa731a..d1f754bd 100644 --- a/ingen/client/BlockModel.hpp +++ b/ingen/client/BlockModel.hpp @@ -64,18 +64,18 @@ public: uint32_t num_ports() const override { return _ports.size(); } const Ports& ports() const { return _ports; } - void default_port_value_range(SPtr port, - float& min, - float& max, - uint32_t srate = 1) const; + void default_port_value_range(const SPtr& port, + float& min, + float& max, + uint32_t srate = 1) const; - void port_value_range(SPtr port, - float& min, - float& max, - uint32_t srate = 1) const; + void port_value_range(const SPtr& port, + float& min, + float& max, + uint32_t srate = 1) const; std::string label() const; - std::string port_label(SPtr port) const; + std::string port_label(const SPtr& port) const; // Signals INGEN_SIGNAL(new_port, void, SPtr); @@ -87,17 +87,19 @@ protected: BlockModel(URIs& uris, const URI& plugin_uri, const Raul::Path& path); - BlockModel(URIs& uris, - SPtr plugin, - const Raul::Path& path); + + BlockModel(URIs& uris, + const SPtr& plugin, + const Raul::Path& path); + explicit BlockModel(const Raul::Path& path); - void add_child(SPtr c) override; - bool remove_child(SPtr c) override; - void add_port(SPtr pm); - void remove_port(SPtr port); + void add_child(const SPtr& c) override; + bool remove_child(const SPtr& c) override; + void add_port(const SPtr& pm); + void remove_port(const SPtr& port); void remove_port(const Raul::Path& port_path); - void set(SPtr model) override; + void set(const SPtr& model) override; virtual void clear(); diff --git a/ingen/client/GraphModel.hpp b/ingen/client/GraphModel.hpp index 8713b6a9..c3339048 100644 --- a/ingen/client/GraphModel.hpp +++ b/ingen/client/GraphModel.hpp @@ -64,11 +64,11 @@ private: {} void clear() override; - void add_child(SPtr c) override; - bool remove_child(SPtr o) override; - void remove_arcs_on(SPtr p); + void add_child(const SPtr& c) override; + bool remove_child(const SPtr& o) override; + void remove_arcs_on(const SPtr& p); - void add_arc(SPtr arc); + void add_arc(const SPtr& arc); void remove_arc(const ingen::Node* tail, const ingen::Node* head); }; diff --git a/ingen/client/ObjectModel.hpp b/ingen/client/ObjectModel.hpp index 94906dec..535bcdd2 100644 --- a/ingen/client/ObjectModel.hpp +++ b/ingen/client/ObjectModel.hpp @@ -80,11 +80,11 @@ protected: ObjectModel(const ObjectModel& copy); void set_path(const Raul::Path& p) override; - virtual void set_parent(SPtr p); - virtual void add_child(SPtr c) {} - virtual bool remove_child(SPtr c) { return true; } + virtual void set_parent(const SPtr& p); + virtual void add_child(const SPtr& c) {} + virtual bool remove_child(const SPtr& c) { return true; } - virtual void set(SPtr o); + virtual void set(const SPtr& o); SPtr _parent; diff --git a/ingen/client/PortModel.hpp b/ingen/client/PortModel.hpp index 4aa033d1..8bdf0398 100644 --- a/ingen/client/PortModel.hpp +++ b/ingen/client/PortModel.hpp @@ -82,10 +82,10 @@ private: , _direction(dir) {} - void add_child(SPtr c) override { throw; } - bool remove_child(SPtr c) override { throw; } + void add_child(const SPtr& c) override { throw; } + bool remove_child(const SPtr& c) override { throw; } - void set(SPtr model) override; + void set(const SPtr& model) override; uint32_t _index; Direction _direction; -- cgit v1.2.1