diff --git a/Framework/Kernel/inc/MantidKernel/UsageService.h b/Framework/Kernel/inc/MantidKernel/UsageService.h index 15feb908cf8483d830ccb1a79d0b4538730c2e68..7094bb1dd4fc88120592ec6d7dc0ae88cffc264e 100644 --- a/Framework/Kernel/inc/MantidKernel/UsageService.h +++ b/Framework/Kernel/inc/MantidKernel/UsageService.h @@ -41,7 +41,8 @@ enum class FeatureType { Algorithm, Interface, Feature }; class FeatureUsage { public: /// Constructor - FeatureUsage(const FeatureType &type, std::string name, const bool internal); + FeatureUsage(const FeatureType &type, std::string name, const bool internal, + std::string application); bool operator<(const FeatureUsage &r) const; ::Json::Value asJson() const; @@ -49,6 +50,7 @@ public: FeatureType type; std::string name; bool internal; + std::string application; protected: std::string featureTypeToString() const; diff --git a/Framework/Kernel/src/UsageService.cpp b/Framework/Kernel/src/UsageService.cpp index f6e5638d7cd5f48a242008346d6056f1808e99be..81a8a3630baeb6e5449e0a71ca655eb128d8ade7 100644 --- a/Framework/Kernel/src/UsageService.cpp +++ b/Framework/Kernel/src/UsageService.cpp @@ -37,8 +37,9 @@ Kernel::Logger g_log("UsageServiceImpl"); /** FeatureUsage */ FeatureUsage::FeatureUsage(const FeatureType &type, std::string name, - const bool internal) - : type(type), name(std::move(name)), internal(internal) {} + const bool internal, std::string application) + : type(type), name(std::move(name)), internal(internal), + application(std::move(application)) {} // Better brute force. bool FeatureUsage::operator<(const FeatureUsage &r) const { @@ -80,6 +81,7 @@ std::string FeatureUsage::featureTypeToString() const { retVal["type"] = featureTypeToString(); retVal["name"] = name; retVal["internal"] = internal; + retVal["application"] = application; return retVal; } @@ -136,7 +138,8 @@ void UsageServiceImpl::registerFeatureUsage( std::lock_guard<std::mutex> _lock(m_mutex); using boost::algorithm::join; - m_FeatureQueue.push(FeatureUsage(type, join(name, SEPARATOR), internal)); + m_FeatureQueue.push(FeatureUsage(type, join(name, SEPARATOR), internal, + getApplicationName())); } } @@ -145,8 +148,8 @@ void UsageServiceImpl::registerFeatureUsage(const FeatureType &type, const bool internal) { if (isEnabled()) { std::lock_guard<std::mutex> _lock(m_mutex); - - m_FeatureQueue.push(FeatureUsage(type, name, internal)); + m_FeatureQueue.push( + FeatureUsage(type, name, internal, getApplicationName())); } }