Skip to content

Commit

Permalink
Merge branch 'v2.10'
Browse files Browse the repository at this point in the history
  • Loading branch information
carlocamilloni committed Oct 10, 2024
2 parents ba5e90d + 0ddd460 commit 2dfbfc8
Show file tree
Hide file tree
Showing 5 changed files with 61 additions and 11 deletions.
4 changes: 2 additions & 2 deletions regtest/basic/rt-make-exceptions/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ int main(){
int natoms=10;

std::vector<double> positions(3*natoms,0.0);
for(unsigned i=0;i<3*natoms;i++) positions[i]=i;
for(int i=0;i<3*natoms;i++) positions[i]=i;
std::vector<double> masses(natoms,1.0);
std::vector<double> forces(3*natoms,0.0);
std::vector<double> box(9,0.0);
Expand Down Expand Up @@ -145,7 +145,7 @@ int main(){
plumed.cmd("setVirial",&virial[0]);
plumed.cmd("setMasses",&masses[0]);
// set positions after having passed the pointer. They should be accessed here (at "calc").
for(unsigned i=0;i<3*natoms;i++) positions[i]=i*step;
for(int i=0;i<3*natoms;i++) positions[i]=i*step;
plumed.cmd("calc");

// this should fail
Expand Down
16 changes: 15 additions & 1 deletion src/core/ActionRegister.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
along with plumed. If not, see <http://www.gnu.org/licenses/>.
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
#include "ActionRegister.h"
#include "ModuleMap.h"
#include "Action.h"
#include <algorithm>

Expand All @@ -35,7 +36,7 @@ std::unique_ptr<Action> ActionRegister::create(const ActionOptions&ao) {
return create(images,ao);
}

std::unique_ptr<Action> ActionRegister::create(const std::vector<void*> & images,const ActionOptions&ao) {
std::unique_ptr<Action> ActionRegister::create(const std::vector<void*> & images,const ActionOptions&ao) try {
if(ao.line.size()<1)return nullptr;

auto content=get(images,ao.line[0]);
Expand All @@ -45,6 +46,17 @@ std::unique_ptr<Action> ActionRegister::create(const std::vector<void*> & images
auto fullPath=getFullPath(images,ao.line[0]);
nao.setFullPath(fullPath);
return content.create(nao);
} catch (PLMD::ExceptionRegisterError &e ) {
auto& actionName = e.getMissingKey();
e <<"Action \"" << actionName << "\" is not known.";
if (getModuleMap().count(actionName)>0) {
e << "\nAn Action named \""
<<actionName
<<"\" is available in module \""
<< getModuleMap().at(actionName)
<< "\".\nPlease consider installing PLUMED with that module enabled.";
}
throw e;
}

bool ActionRegister::printManual(const std::string& action, const bool& vimout, const bool& spellout) {
Expand All @@ -64,6 +76,7 @@ bool ActionRegister::printManual(const std::string& action, const bool& vimout,
}

bool ActionRegister::printTemplate(const std::string& action, bool include_optional) {
//no need to insert the try/catch block: check will ensure that action is known
if( check(action) ) {
Keywords keys; keys.thisactname = action;
get(action).keys(keys);
Expand All @@ -85,6 +98,7 @@ ActionRegister::ID ActionRegister::add(std::string key,creator_pointer cp,keywor
}

bool ActionRegister::getKeywords(const std::string& action, Keywords& keys) {
//no need to insert the try/catch block: check will ensure that action is known
if(check(action)) {
keys.thisactname = action;
get(action).keys(keys);
Expand Down
5 changes: 4 additions & 1 deletion src/core/CLToolRegister.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,11 +38,14 @@ std::unique_ptr<CLTool> CLToolRegister::create(const CLToolOptions&ao) {
return create(images,ao);
}

std::unique_ptr<CLTool> CLToolRegister::create(const std::vector<void*> & images,const CLToolOptions&ao) {
std::unique_ptr<CLTool> CLToolRegister::create(const std::vector<void*> & images,const CLToolOptions&ao) try {
if(ao.line.size()<1)return nullptr;
auto & content=get(images,ao.line[0]);
CLToolOptions nao( ao,content.keys );
return content.create(nao);
} catch (PLMD::ExceptionRegisterError &e ) {
auto& toolName = e.getMissingKey();
throw e <<"CL tool \"" << toolName << "\" is not known.";
}

CLToolRegister::ID CLToolRegister::add(std::string key,creator_pointer cp,keywords_pointer kp) {
Expand Down
43 changes: 38 additions & 5 deletions src/core/RegisterBase.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@

#include "tools/Exception.h"
#include <string>
#include <string_view>
#include <map>
#include <memory>
#include <iostream>
Expand Down Expand Up @@ -95,6 +96,34 @@ class Register {
friend std::ostream & operator<<(std::ostream &log,const Register &reg);
};

/// Class representing an error in a register
class ExceptionRegisterError :
public Exception {
/// The missing key
std::string missingKey;
public:
using Exception::Exception;
/// Sets the missing key
/// \param key The missing key
/// \return This exception
///
/// ExceptionRegisterError can be used as a builder pattern:
/// `throw ExceptionRegisterError().setMissingKey(key);`
///
/// the key can be retrieved with ExceptionRegisterError::getMissingKey()
ExceptionRegisterError& setMissingKey (std::string_view key) {
missingKey=key;
return *this;
}
/// Returns the missing key
const std::string& getMissingKey() const {return missingKey;}
template<typename T>
ExceptionRegisterError& operator<<(const T & x) {
*static_cast<Exception*>(this) <<x;
return *this;
}
};

/// General register.
/// This class provide a generic implementation based on the content of the Register
template<class Content>
Expand Down Expand Up @@ -208,7 +237,9 @@ const Content & RegisterBase<Content>::get(const std::vector<void*> & images,con
auto qualified_key=imageToString(*image) + ":" + key;
if(m.count(qualified_key)>0) return m.find(qualified_key)->second->content;
}
plumed_assert(m.count(key)>0);
if (m.count(key) == 0 ) {
throw ExceptionRegisterError().setMissingKey(key);
}
return m.find(key)->second->content;
}

Expand All @@ -220,15 +251,19 @@ const std::string & RegisterBase<Content>::getFullPath(const std::vector<void*>
auto qualified_key=imageToString(*image) + ":" + key;
if(m.count(qualified_key)>0) return m.find(qualified_key)->second->fullPath;
}
plumed_assert(m.count(key)>0);
if (m.count(key) == 0 ) {
throw ExceptionRegisterError().setMissingKey(key);
}
return m.find(key)->second->fullPath;
}

template<class Content>
const Content & RegisterBase<Content>::get(const std::string & key) const {
// lock map for reading
std::shared_lock<std::shared_mutex> lock(mutex);
plumed_assert(m.count(key)>0);
if (m.count(key) == 0 ) {
throw ExceptionRegisterError().setMissingKey(key);
}
return m.find(key)->second->content;
}

Expand Down Expand Up @@ -288,5 +323,3 @@ void RegisterBase<Content>::clearStaged() noexcept {
}

#endif


4 changes: 2 additions & 2 deletions src/wrapper/Plumed.h
Original file line number Diff line number Diff line change
Expand Up @@ -2346,7 +2346,7 @@ class Plumed {
char msg[__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER];
void init(const char* msg) __PLUMED_WRAPPER_CXX_NOEXCEPT {
this->msg[0]='\0';
__PLUMED_WRAPPER_STD strncat(this->msg,msg,__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER-1);
__PLUMED_WRAPPER_STD strncpy(this->msg,msg,__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER);
this->msg[__PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER-1]='\0';
if(PlumedGetenvExceptionsDebug() && __PLUMED_WRAPPER_STD strlen(msg) > __PLUMED_WRAPPER_CXX_EXCEPTION_BUFFER-1) __PLUMED_WRAPPER_STD fprintf(stderr,"+++ WARNING: message will be truncated\n");
}
Expand Down Expand Up @@ -3831,7 +3831,7 @@ void* plumed_attempt_dlopen(const char*path,int mode) {
__PLUMED_FPRINTF(stderr,"+++ Allocation error +++\n");
__PLUMED_WRAPPER_STD abort();
}
__PLUMED_WRAPPER_STD strncpy(pathcopy,path,strlenpath+1);
__PLUMED_WRAPPER_STD memcpy(pathcopy,path,strlenpath+1);
pc=pathcopy+strlenpath-6;
while(pc>=pathcopy && __PLUMED_WRAPPER_STD memcmp(pc,"Kernel",6)) pc--;
if(pc>=pathcopy) {
Expand Down

1 comment on commit 2dfbfc8

@PlumedBot
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Found broken examples in automatic/ANGLES.tmp
Found broken examples in automatic/ANN.tmp
Found broken examples in automatic/CAVITY.tmp
Found broken examples in automatic/CLASSICAL_MDS.tmp
Found broken examples in automatic/CLUSTER_DIAMETER.tmp
Found broken examples in automatic/CLUSTER_DISTRIBUTION.tmp
Found broken examples in automatic/CLUSTER_PROPERTIES.tmp
Found broken examples in automatic/CONSTANT.tmp
Found broken examples in automatic/CONTACT_MATRIX.tmp
Found broken examples in automatic/CONTACT_MATRIX_PROPER.tmp
Found broken examples in automatic/CONVERT_TO_FES.tmp
Found broken examples in automatic/COORDINATIONNUMBER.tmp
Found broken examples in automatic/DFSCLUSTERING.tmp
Found broken examples in automatic/DISTANCE_FROM_CONTOUR.tmp
Found broken examples in automatic/DUMPCUBE.tmp
Found broken examples in automatic/DUMPGRID.tmp
Found broken examples in automatic/EDS.tmp
Found broken examples in automatic/EMMI.tmp
Found broken examples in automatic/ENVIRONMENTSIMILARITY.tmp
Found broken examples in automatic/FIND_CONTOUR.tmp
Found broken examples in automatic/FIND_CONTOUR_SURFACE.tmp
Found broken examples in automatic/FIND_SPHERICAL_CONTOUR.tmp
Found broken examples in automatic/FOURIER_TRANSFORM.tmp
Found broken examples in automatic/FUNCPATHGENERAL.tmp
Found broken examples in automatic/FUNCPATHMSD.tmp
Found broken examples in automatic/FUNNEL.tmp
Found broken examples in automatic/FUNNEL_PS.tmp
Found broken examples in automatic/GHBFIX.tmp
Found broken examples in automatic/GPROPERTYMAP.tmp
Found broken examples in automatic/HBOND_MATRIX.tmp
Found broken examples in automatic/HISTOGRAM.tmp
Found broken examples in automatic/INCLUDE.tmp
Found broken examples in automatic/INCYLINDER.tmp
Found broken examples in automatic/INENVELOPE.tmp
Found broken examples in automatic/INTERPOLATE_GRID.tmp
Found broken examples in automatic/LOCAL_AVERAGE.tmp
Found broken examples in automatic/MAZE_OPTIMIZER_BIAS.tmp
Found broken examples in automatic/MAZE_RANDOM_ACCELERATION_MD.tmp
Found broken examples in automatic/MAZE_SIMULATED_ANNEALING.tmp
Found broken examples in automatic/MAZE_STEERED_MD.tmp
Found broken examples in automatic/METATENSOR.tmp
Found broken examples in automatic/MULTICOLVARDENS.tmp
Found broken examples in automatic/OUTPUT_CLUSTER.tmp
Found broken examples in automatic/PAMM.tmp
Found broken examples in automatic/PCA.tmp
Found broken examples in automatic/PCAVARS.tmp
Found broken examples in automatic/PIV.tmp
Found broken examples in automatic/PLUMED.tmp
Found broken examples in automatic/PYCVINTERFACE.tmp
Found broken examples in automatic/PYTHONFUNCTION.tmp
Found broken examples in automatic/Q3.tmp
Found broken examples in automatic/Q4.tmp
Found broken examples in automatic/Q6.tmp
Found broken examples in automatic/QUATERNION.tmp
Found broken examples in automatic/REWEIGHT_BIAS.tmp
Found broken examples in automatic/REWEIGHT_METAD.tmp
Found broken examples in automatic/SIZESHAPE_POSITION_LINEAR_PROJ.tmp
Found broken examples in automatic/SIZESHAPE_POSITION_MAHA_DIST.tmp
Found broken examples in automatic/SPRINT.tmp
Found broken examples in automatic/TETRAHEDRALPORE.tmp
Found broken examples in automatic/TORSIONS.tmp
Found broken examples in automatic/WHAM_HISTOGRAM.tmp
Found broken examples in automatic/WHAM_WEIGHTS.tmp
Found broken examples in AnalysisPP.md
Found broken examples in CollectiveVariablesPP.md
Found broken examples in MiscelaneousPP.md

Please sign in to comment.