From 8ec8e47924a9860694a742c598ffd27b8fb04868 Mon Sep 17 00:00:00 2001 From: Sinisa Veseli Date: Fri, 17 Nov 2023 12:58:58 -0600 Subject: [PATCH] fix static build --- src/copy/dataDistributorPlugin.cpp | 9 ++++++--- src/database/pvDatabase.cpp | 2 ++ test/src/testPlugin.cpp | 6 +++--- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/src/copy/dataDistributorPlugin.cpp b/src/copy/dataDistributorPlugin.cpp index 1e17ad2..151b235 100644 --- a/src/copy/dataDistributorPlugin.cpp +++ b/src/copy/dataDistributorPlugin.cpp @@ -83,7 +83,7 @@ static std::string toLowerCase(const std::string& input) // Data distributor class static std::string name("distributor"); -bool DataDistributorPlugin::initialized(DataDistributorPlugin::initialize()); +bool DataDistributorPlugin::initialized(false); std::map DataDistributor::dataDistributorMap; epics::pvData::Mutex DataDistributor::dataDistributorMapMutex; @@ -275,8 +275,11 @@ void DataDistributorPlugin::create() bool DataDistributorPlugin::initialize() { - DataDistributorPluginPtr pvPlugin = DataDistributorPluginPtr(new DataDistributorPlugin()); - PVPluginRegistry::registerPlugin(name,pvPlugin); + if (not initialized) { + initialized = true; + DataDistributorPluginPtr pvPlugin = DataDistributorPluginPtr(new DataDistributorPlugin()); + PVPluginRegistry::registerPlugin(name,pvPlugin); + } return true; } diff --git a/src/database/pvDatabase.cpp b/src/database/pvDatabase.cpp index ec7fcf8..d72d5ce 100644 --- a/src/database/pvDatabase.cpp +++ b/src/database/pvDatabase.cpp @@ -23,6 +23,7 @@ #include "pv/pvArrayPlugin.h" #include "pv/pvTimestampPlugin.h" #include "pv/pvDeadbandPlugin.h" +#include "pv/dataDistributorPlugin.h" using std::tr1::static_pointer_cast; using namespace epics::pvData; @@ -44,6 +45,7 @@ PVDatabasePtr PVDatabase::getMaster() PVArrayPlugin::create(); PVTimestampPlugin::create(); PVDeadbandPlugin::create(); + DataDistributorPlugin::create(); } return pvDatabaseMaster; } diff --git a/test/src/testPlugin.cpp b/test/src/testPlugin.cpp index 4f83a6e..4e1cda7 100644 --- a/test/src/testPlugin.cpp +++ b/test/src/testPlugin.cpp @@ -366,7 +366,7 @@ static void dataDistributorTest() PVCopyPtr pvCopy1(PVCopy::create(pvRecordStructure,pvRequest,"")); PVStructurePtr pvStructureCopy1(pvCopy1->createPVStructure()); BitSetPtr bitSet1(new BitSet(pvStructureCopy1->getNumberFields())); - + PVCopyPtr pvCopy2(PVCopy::create(pvRecordStructure,pvRequest,"")); PVStructurePtr pvStructureCopy2(pvCopy2->createPVStructure()); BitSetPtr bitSet2(new BitSet(pvStructureCopy2->getNumberFields())); @@ -383,7 +383,7 @@ static void dataDistributorTest() debugOutput("client 2: update 0", result, nSet, bitSet2, pvStructureCopy2); testOk1(result==true); testOk1(nSet==1); - + // Update 1: only client 1 gets it pvValue->put(1); @@ -398,7 +398,7 @@ static void dataDistributorTest() debugOutput("client 2: update 1", result, nSet, bitSet2, pvStructureCopy2); testOk1(result==false); testOk1(nSet==0); - + // Update 2: only client 2 gets it pvValue->put(2);