Changes in / [ec149d:f761c4]
- Files:
-
- 33 edited
Legend:
- Unmodified
- Added
- Removed
-
Makefile.am
rec149d rf761c4 7 7 doc: 8 8 cd doc && make doxygen-docs 9 10 unity: 11 cd src && make unity -
src/Actions/CmdAction/FastParsingAction.cpp
rec149d rf761c4 78 78 79 79 Action::state_ptr CommandLineFastParsingAction::performRedo(Action::state_ptr _state){ 80 performUndo(_state);80 return performUndo(_state); 81 81 } 82 82 -
src/Actions/CmdAction/VerboseAction.cpp
rec149d rf761c4 76 76 77 77 Action::state_ptr CommandLineVerboseAction::performRedo(Action::state_ptr _state){ 78 performUndo(_state);78 return performUndo(_state); 79 79 } 80 80 -
src/Actions/FragmentationAction/SubgraphDissectionAction.hpp
rec149d rf761c4 7 7 8 8 #ifndef SUBGRAPHDISSECTIONACTION_HPP_ 9 #define SUBGRAPHDISSECTIONACTION_HPP_ f9 #define SUBGRAPHDISSECTIONACTION_HPP_ 10 10 11 11 #include "Actions/Action.hpp" -
src/Actions/Makefile.am
rec149d rf761c4 168 168 WorldAction/SetOutputFormatsAction.hpp 169 169 170 unity.cpp: 171 echo "" > unity.cpp; \ 172 list='$(ACTIONSSOURCE)'; for file in $$list; do \ 173 echo "#include \"$(srcdir)/$$file\"" >> unity.cpp; \ 174 done; 175 176 MOSTLYCLEANFILES = unity.cpp -
src/Actions/SelectionAction/NotAllAtomsAction.cpp
rec149d rf761c4 28 28 // memento to remember the state when undoing 29 29 30 class Selection AllAtomsState : public ActionState {30 class SelectionNotAllAtomsState : public ActionState { 31 31 public: 32 Selection AllAtomsState(std::vector<atom*> _selectedAtoms) :32 SelectionNotAllAtomsState(std::vector<atom*> _selectedAtoms) : 33 33 selectedAtoms(_selectedAtoms) 34 34 {} … … 61 61 DoLog(1) && (Log() << Verbose(1) << "Unselecting all atoms." << endl); 62 62 World::getInstance().clearAtomSelection(); 63 return Action::state_ptr(new Selection AllAtomsState(selectedAtoms));63 return Action::state_ptr(new SelectionNotAllAtomsState(selectedAtoms)); 64 64 } 65 65 66 66 Action::state_ptr SelectionNotAllAtomsAction::performUndo(Action::state_ptr _state) { 67 Selection AllAtomsState *state = assert_cast<SelectionAllAtomsState*>(_state.get());67 SelectionNotAllAtomsState *state = assert_cast<SelectionNotAllAtomsState*>(_state.get()); 68 68 69 69 World::getInstance().clearAtomSelection(); … … 71 71 World::getInstance().selectAtom(*iter); 72 72 73 return Action::state_ptr(new Selection AllAtomsState(state->selectedAtoms));73 return Action::state_ptr(new SelectionNotAllAtomsState(state->selectedAtoms)); 74 74 } 75 75 76 76 Action::state_ptr SelectionNotAllAtomsAction::performRedo(Action::state_ptr _state){ 77 Selection AllAtomsState *state = assert_cast<SelectionAllAtomsState*>(_state.get());77 SelectionNotAllAtomsState *state = assert_cast<SelectionNotAllAtomsState*>(_state.get()); 78 78 79 79 World::getInstance().clearAtomSelection(); 80 80 81 return Action::state_ptr(new Selection AllAtomsState(state->selectedAtoms));81 return Action::state_ptr(new SelectionNotAllAtomsState(state->selectedAtoms)); 82 82 } 83 83 -
src/Actions/WorldAction/SetDefaultNameAction.cpp
rec149d rf761c4 79 79 80 80 Action::state_ptr WorldSetDefaultNameAction::performRedo(Action::state_ptr _state){ 81 performUndo(_state);81 return performUndo(_state); 82 82 } 83 83 -
src/Actions/WorldAction/SetGaussianBasisAction.cpp
rec149d rf761c4 79 79 80 80 Action::state_ptr WorldSetGaussianBasisAction::performRedo(Action::state_ptr _state){ 81 performUndo(_state);81 return performUndo(_state); 82 82 } 83 83 -
src/Formula.cpp
rec149d rf761c4 55 55 56 56 void Formula::fromString(const std::string &formula) throw(ParseError){ 57 // make this transactional, in case an error is thrown 58 Formula res; 59 string::const_iterator begin = formula.begin(); 60 string::const_iterator end = formula.end(); 61 res.parseFromString(begin,end,static_cast<char>(0)); 62 (*this)=res; 63 } 64 65 int Formula::parseMaybeNumber(string::const_iterator &it,string::const_iterator &end) throw(ParseError){ 66 static const range<char> Numbers = makeRange('0',static_cast<char>('9'+1)); 67 int count = 0; 68 while(it!=end && Numbers.isInRange(*it)) 69 count = (count*10) + ((*it++)-Numbers.first); 70 // one is implicit 71 count = (count!=0)?count:1; 72 return count; 73 } 74 75 void Formula::parseFromString(string::const_iterator &it,string::const_iterator &end,char delimiter) throw(ParseError){ 57 76 // some constants needed for parsing... Assumes ASCII, change if other encodings are used 58 77 static const range<char> CapitalLetters = makeRange('A',static_cast<char>('Z'+1)); 59 78 static const range<char> SmallLetters = makeRange('a',static_cast<char>('z'+1)); 60 static const range<char> Numbers = makeRange('0',static_cast<char>('9'+1)); 79 map<char,char> delimiters; 80 delimiters['('] = ')'; 81 delimiters['['] = ']'; 61 82 // clean the formula 62 83 clear(); 63 string::const_iterator end = formula.end(); // will be used frequently 64 for(string::const_iterator it=formula.begin();it!=end;){ 84 for(/*send from above*/;it!=end && *it!=delimiter;/*updated in loop*/){ 85 // we might have a sub formula 86 if(delimiters.count(*it)){ 87 Formula sub; 88 char nextdelim=delimiters[*it]; 89 sub.parseFromString(++it,end,nextdelim); 90 if(!sub.getElementCount()){ 91 throw(ParseError(__FILE__,__LINE__)); 92 } 93 int count = parseMaybeNumber(++it,end); 94 addFormula(sub,count); 95 continue; 96 } 65 97 string shorthand; 66 98 // Atom names start with a capital letter … … 71 103 while(it!=end && SmallLetters.isInRange(*it)) 72 104 shorthand+=(*it++); 73 // now we can count the occurences 74 int count = 0; 75 while(it!=end && Numbers.isInRange(*it)) 76 count = (count*10) + ((*it++)-Numbers.first); 77 // one is implicit 78 count = (count!=0)?count:1; 105 int count = parseMaybeNumber(it,end); 79 106 // test if the shorthand exists 80 107 if(!World::getInstance().getPeriode()->FindElement(shorthand)) … … 83 110 addElements(shorthand,count); 84 111 } 112 if(it==end && delimiter!=0){ 113 throw(ParseError(__FILE__,__LINE__)); 114 } 85 115 } 86 116 … … 93 123 *output << "#Ion_TypeNr.\tAmount\tZ\tRGauss\tL_Max(PP)L_Loc(PP)IonMass\t# chemical name, symbol" << endl; 94 124 for(const_iterator iter=begin(); iter!=end();++iter){ 95 (*iter).first->No = No;96 125 result = result && (*iter).first->Checkout(output, No++, (*iter).second); 97 126 } … … 195 224 } 196 225 226 void Formula::addFormula(const Formula &formula,unsigned int n){ 227 for(Formula::const_iterator iter=formula.begin();iter!=formula.end();++iter){ 228 this->addElements(iter->first,iter->second*n); 229 } 230 } 231 232 enumeration<Formula::key_type> Formula::enumerateElements() const{ 233 enumeration<key_type> res(1); 234 for(Formula::const_iterator iter=begin();iter!=end();++iter){ 235 res.add(iter->first); 236 } 237 return res; 238 } 239 197 240 const unsigned int Formula::operator[](const element *element) const{ 198 241 ASSERT(element,"Invalid pointer in access of Formula"); -
src/Formula.hpp
rec149d rf761c4 16 16 17 17 #include "types.hpp" 18 #include "helpers.hpp" 18 19 19 20 class element; … … 22 23 { 23 24 public: 24 typedef element*key_type;25 typedef const element* key_type; 25 26 typedef unsigned int mapped_type; 26 27 typedef std::pair<key_type, mapped_type> value_type; … … 65 66 66 67 unsigned int getElementCount() const; 67 bool hasElement( const element*)const;68 bool hasElement(key_type) const; 68 69 bool hasElement(atomicNumber_t) const; 69 70 bool hasElement(const std::string&) const; 70 71 71 void operator+=( const element*);72 void operator+=(key_type); 72 73 void operator+=(atomicNumber_t); 73 74 void operator+=(const std::string&); 74 75 75 void operator-=( const element*);76 void operator-=(key_type); 76 77 void operator-=(atomicNumber_t); 77 78 void operator-=(const std::string&); 78 79 79 void addElements( const element*,unsigned int);80 void addElements(key_type,unsigned int); 80 81 void addElements(atomicNumber_t,unsigned int); 81 82 void addElements(const std::string&,unsigned int); 82 83 84 void addFormula(const Formula&,unsigned int); 85 86 enumeration<key_type> enumerateElements() const; 87 83 88 // only const versions, because someone might try to increment a previously 84 89 // not set element 85 const unsigned int operator[]( const element*) const;90 const unsigned int operator[](key_type) const; 86 91 const unsigned int operator[](atomicNumber_t) const; 87 92 const unsigned int operator[](std::string) const; … … 98 103 99 104 private: 105 void parseFromString(std::string::const_iterator&,std::string::const_iterator&,char) throw(ParseError); 106 int parseMaybeNumber(std::string::const_iterator &it,std::string::const_iterator &end) throw(ParseError); 100 107 // this contains all counts of elements in the formula 101 108 // the size of the actual structure might be used in comparisons -
src/Helpers/Assert.cpp
rec149d rf761c4 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp"9 7 10 8 #include "Helpers/Assert.hpp" … … 46 44 } 47 45 48 using namespace Assert;49 50 46 #ifndef NDEBUG 51 47 52 Action _my_assert::defaultAction = Ask; 53 std::vector<Assert::hook_t> _my_assert::hooks; 48 #ifdef __GNUC__ 49 #include <cstdlib> 50 #include <execinfo.h> 51 #include <cxxabi.h> 52 #endif 54 53 55 std::map<std::string,bool> _wrapper::ignores; 56 const char* _wrapper::message_ptr = "source pointer did not point to object of desired type"; 57 const char* _wrapper::message_ref = "source reference did not contain object of desired type"; 54 Assert::Action Assert::_my_assert::defaultAction = Ask; 55 std::vector<Assert::hook_t> Assert::_my_assert::hooks; 58 56 57 std::map<std::string,bool> Assert::_wrapper::ignores; 58 const char* Assert::_wrapper::message_ptr = "source pointer did not point to object of desired type"; 59 const char* Assert::_wrapper::message_ref = "source reference did not contain object of desired type"; 59 60 60 bool _my_assert::check(const bool res, 61 const char* condition, 62 const char* message, 63 const char* filename, 64 const int line, 65 bool& ignore) 61 bool Assert::_my_assert::check(const char* condition, 62 const char* message, 63 const char* filename, 64 const int line, 65 bool& ignore) 66 66 { 67 if(!res){ 68 cout << "Assertion \"" << condition << "\" failed in file " << filename << " at line " << line << endl; 69 cout << "Assertion Message: " << message << std::endl; 70 while(true){ 71 char choice; 72 if(defaultAction==Ask) { 73 cout << "Please choose: (a)bort, (t)hrow execption, (i)gnore, al(w)ays ignore" << endl; 74 cin >> choice; 75 } 76 else{ 77 choice = ActionKeys[defaultAction]; 78 } 79 switch(choice){ 80 case 'a': 81 return true; 82 break; 83 case 't': 84 throw AssertionFailure(condition,filename,line,message); 85 break; 86 case 'w': 87 ignore = true; 88 // fallthrough 89 case 'i': 90 return false; 91 break; 92 } 67 cout << "Assertion \"" << condition << "\" failed in file " << filename << " at line " << line << endl; 68 cout << "Assertion Message: " << message << std::endl; 69 while(true){ 70 char choice; 71 if(defaultAction==Assert::Ask) { 72 #ifdef __GNUC__ 73 cout << "Please choose: (a)bort, (t)hrow execption, show (b)actrace, (i)gnore, al(w)ays ignore" << endl; 74 #else 75 cout << "Please choose: (a)bort, (t)hrow execption, (i)gnore, al(w)ays ignore" << endl; 76 #endif /* __GNUC__ */ 77 cin >> choice; 78 } 79 else{ 80 choice = ActionKeys[defaultAction]; 81 } 82 switch(choice){ 83 case 'a': 84 return true; 85 break; 86 case 't': 87 throw AssertionFailure(condition,filename,line,message); 88 break; 89 #ifdef __GNUC__ 90 case 'b': 91 Assert::_my_assert::backtrace(filename,line); 92 break; 93 #endif /* __GNUC__ */ 94 case 'w': 95 ignore = true; 96 // fallthrough 97 case 'i': 98 return false; 99 break; 93 100 } 94 101 } … … 96 103 } 97 104 98 void _my_assert::doHooks(){ 105 #ifdef __GNUC__ 106 void Assert::_my_assert::backtrace(const char *file, int line){ 107 const size_t max_depth = 100; 108 void* stack_addrs[max_depth]; 109 size_t stack_depth; 110 char **stack_strings=0; 111 const char *func_name=0; 112 size_t sz = 64; 113 114 // get the backtrace 115 stack_depth = ::backtrace(stack_addrs,max_depth); 116 stack_strings = backtrace_symbols(stack_addrs, stack_depth); 117 // used later for demangling 118 // reserved here, so we can free it unconditionally 119 char *dm_function = static_cast<char*>(malloc(sz)); 120 if(!dm_function){ 121 // malloc failed... we are out of luck 122 cout << "cannot provide stack trace due to exhausted memory" << endl; 123 return; 124 } 125 126 cout << "Backtrace from " << file << "@" << line << ":" << endl; 127 128 // i=2 because we don't want this function, nor the assertion handler 129 for(unsigned int i=2;i<stack_depth-2;++i){ 130 // find the mangled function name 131 char *begin = stack_strings[i]; 132 // function name starts with a ( 133 while(*begin && *begin!='(') ++begin; 134 char *end=begin; 135 while(*end && *end!='+') ++end; 136 137 // see if we found our function name 138 if(*begin && *end){ 139 *begin++ = 0; 140 *end = 0; 141 // use the C++ demangler 142 143 int status; 144 char *func_ret = abi::__cxa_demangle(begin, dm_function, &sz, &status); 145 if(func_ret){ 146 // abi might have realloced... 147 dm_function = func_ret; 148 func_name = dm_function; 149 } 150 else{ 151 // demangling failed... get the function name without demangling 152 func_name = begin; 153 } 154 } 155 else{ 156 // function name not found... get the whole line 157 func_name = stack_strings[i]; 158 } 159 cout << func_name << endl; 160 } 161 free(dm_function); 162 free(stack_strings); // malloc()ed by backtrace_symbols 163 } 164 #endif /* __GNUC__ */ 165 166 void Assert::_my_assert::doHooks(){ 99 167 for(vector<hook_t>::reverse_iterator iter = hooks.rbegin(); iter!=hooks.rend(); ++iter ){ 100 168 (*iter)(); … … 102 170 } 103 171 104 void _my_assert::addHook(hook_t hook){172 void Assert::_my_assert::addHook(hook_t hook){ 105 173 hooks.push_back(hook); 106 174 } 107 175 108 void _my_assert::removeHook(Assert::hook_t hook){176 void Assert::_my_assert::removeHook(Assert::hook_t hook){ 109 177 for(vector<hook_t>::iterator iter = hooks.begin(); iter!=hooks.end();){ 110 178 if((*iter)==hook){ … … 117 185 } 118 186 119 void _my_assert::setDefault(Assert::Action action){187 void Assert::_my_assert::setDefault(Assert::Action action){ 120 188 defaultAction = action; 121 189 } 122 Assert::Action _my_assert::getDefault(){190 Assert::Action Assert::_my_assert::getDefault(){ 123 191 return defaultAction; 124 192 } 125 std::string _my_assert::printDefault(){193 std::string Assert::_my_assert::printDefault(){ 126 194 return ActionNames[defaultAction]; 127 195 } -
src/Helpers/Assert.hpp
rec149d rf761c4 234 234 static bool ignore = false;\ 235 235 if(!ignore){\ 236 if( Assert::_my_assert::check((condition),STRINGIFY(condition),(message),\237 __FILE__,__LINE__,ignore)){\236 if(!(condition) && Assert::_my_assert::check(STRINGIFY(condition),(message),\ 237 __FILE__,__LINE__,ignore)){\ 238 238 Assert::_my_assert::doHooks();\ 239 239 DEBUG_BREAK;\ … … 247 247 static bool ignore = false; \ 248 248 if(!ignore){\ 249 if(Assert::_my_assert::check( false,"Exception caught",(message),__FILE__,__LINE__,ignore)){\249 if(Assert::_my_assert::check("Exception caught",(message),__FILE__,__LINE__,ignore)){\ 250 250 Assert::_my_assert::doHooks();\ 251 DEBUG_BREAK;\251 DEBUG_BREAK;\ 252 252 }\ 253 253 }\ … … 299 299 class _my_assert{ 300 300 public: 301 static bool check(const bool res, 302 const char* condition, 301 static bool check(const char* condition, 303 302 const char* message, 304 303 const char* filename, 305 304 const int line, 306 305 bool& ignore); 306 #ifdef __GNUC__ 307 static void backtrace(const char *file, int line); 308 #endif /* __GNUC__ */ 307 309 static void addHook(Assert::hook_t hook); 308 310 static void removeHook(Assert::hook_t hook); … … 332 334 333 335 if(!ignore){ 334 if(_my_assert::check(dynamic_cast<target>(src)==static_cast<target>(src),"type-safe typecast",335 336 bool res = dynamic_cast<target>(src)==static_cast<target>(src); 337 if(!res && _my_assert::check("type-safe typecast",message_ptr,file,line,ignore)){ 336 338 _my_assert::doHooks(); 337 339 DEBUG_BREAK; … … 354 356 catch(...){ 355 357 if(!ignore){ 356 if(_my_assert::check( 0,"type-safe typecast",message_ref,file,line,ignore)){358 if(_my_assert::check("type-safe typecast",message_ref,file,line,ignore)){ 357 359 _my_assert::doHooks(); 358 360 DEBUG_BREAK; -
src/Helpers/MemDebug.cpp
rec149d rf761c4 72 72 // all allocated memory blocks 73 73 struct entry_t { 74 typedef unsigned int checksum_t; 74 75 // we seperate the tracking info from the rest 75 76 // A checksum will be calculated for this part of … … 90 91 } info; 91 92 bool isIgnored; 92 ch archecksum;93 checksum_t checksum; 93 94 entry_t *prev; 94 95 entry_t *next; … … 117 118 // calculates a simple checksum for the info block 118 119 // the checksum is used to find memory corruptions 119 inline charcalcChecksum(entry_t::info_t *info){120 inline entry_t::checksum_t calcChecksum(entry_t::info_t *info){ 120 121 char *buffer = (char*)info; 121 charchecksum =0;122 entry_t::checksum_t checksum =0; 122 123 for(size_t i=0;i<sizeof(entry_t::info_t);i++){ 123 124 checksum+=buffer[i]; … … 154 155 cout << "Chunk reserved at: " << pos->info.file << ":" << pos->info.line << endl; 155 156 #endif 157 } 158 } 159 160 void dumpMemory(std::ostream &ost){ 161 ost << "Maximum allocated Memory: " << max << " bytes" << endl; 162 ost << "Maximum allocated Memory: " << max << " bytes" << endl; 163 ost << "Currently allocated Memory: " << state <<" bytes" << endl; 164 ost << allocs << " allocated chunks total" << endl; 165 bool corrupted=false; 166 for(entry_t *pos=begin;pos;pos=pos->next){ 167 ost << "\nChunk of " << pos->info.nbytes << " bytes" << " still available" << endl; 168 # ifdef __GNUC__ 169 ost << "Chunk reserved at: " << pos->info.function 170 << " (" << pos->info.file << ":" << pos->info.line << ")" << endl; 171 # else 172 ost << "Chunk reserved at: " << pos->info.file << ":" << pos->info.line << endl; 173 # endif 174 ost << "Chunk address: " << pos->info.location << endl; 175 entry_t::checksum_t checksum = calcChecksum(&pos->info); 176 ost << "Checksum of chunk: " << checksum << endl; 177 ost << "Checksum at allocation time: " << pos->checksum << endl; 178 if(checksum!=pos->checksum){ 179 ost << "!!!Chunk was corrupted!!!" << endl; 180 corrupted=true; 181 } 182 } 183 if(corrupted){ 184 ost << "\n!!!Memory corruption detected!!!" << endl; 156 185 } 157 186 } -
src/Helpers/MemDebug.hpp
rec149d rf761c4 61 61 */ 62 62 void getState(); 63 void dumpMemory(std::ostream&); 63 64 64 65 void _ignore(void*); … … 105 106 inline void getState(){} 106 107 108 inline void dumpMemory(std::ostream&){}; 109 107 110 template <typename T> 108 111 inline T *ignore(T* ptr){ -
src/Makefile.am
rec149d rf761c4 8 8 Helpers/Assert.cpp \ 9 9 Helpers/MemDebug.cpp 10 11 BASESOURCE = \ 12 ${HELPERSOURCE} \ 13 Space.cpp \ 14 vector.cpp 15 16 BASEHEADER = \ 17 ${HELPERHEADER} \ 18 Space.hpp \ 19 vector.hpp 10 20 11 21 ATOMSOURCE = \ … … 31 41 32 42 LINALGSOURCE = \ 33 ${HELPERSOURCE} \34 43 gslmatrix.cpp \ 35 44 gslvector.cpp \ 36 linearsystemofequations.cpp \ 37 Space.cpp \ 38 vector.cpp 45 linearsystemofequations.cpp 39 46 40 47 LINALGHEADER = \ 41 48 gslmatrix.hpp \ 42 49 gslvector.hpp \ 43 linearsystemofequations.hpp \ 44 Space.hpp \ 45 vector.hpp 50 linearsystemofequations.hpp 46 51 47 52 ANALYSISSOURCE = \ … … 132 137 Shapes/Shape.hpp \ 133 138 Shapes/ShapeOps.hpp 139 134 140 135 136 QTUIMOC_HEADER = UIElements/QT4/QTDialog.hpp \137 UIElements/QT4/QTMainWindow.hpp \138 UIElements/Menu/QT4/QTMenu.hpp \139 UIElements/Views/QT4/QTWorldView.hpp \140 UIElements/Views/QT4/GLMoleculeView.hpp \141 UIElements/Views/QT4/QTMoleculeView.hpp \142 UIElements/Views/QT4/QTStatusBar.hpp143 144 QTUIMOC_TARGETS = QTMainWindow.moc.cpp \145 QTMenu.moc.cpp\146 QTDialog.moc.cpp \147 QTWorldView.moc.cpp \148 GLMoleculeView.moc.cpp \149 QTMoleculeView.moc.cpp \150 QTStatusBar.moc.cpp151 152 141 DESCRIPTORSOURCE = Descriptors/AtomDescriptor.cpp \ 153 142 Descriptors/AtomIdDescriptor.cpp \ … … 172 161 Descriptors/MoleculePtrDescriptor.hpp \ 173 162 Descriptors/MoleculeSelectionDescriptor.cpp 163 164 165 QTUIMOC_HEADER = UIElements/QT4/QTDialog.hpp \ 166 UIElements/QT4/QTMainWindow.hpp \ 167 UIElements/Menu/QT4/QTMenu.hpp \ 168 UIElements/Views/QT4/QTWorldView.hpp \ 169 UIElements/Views/QT4/GLMoleculeView.hpp \ 170 UIElements/Views/QT4/QTMoleculeView.hpp \ 171 UIElements/Views/QT4/QTStatusBar.hpp 174 172 175 QTUISOURCE = ${QTUIMOC_TARGETS}\173 QTUISOURCE = allmocs.moc.cpp \ 176 174 UIElements/QT4/QTMainWindow.cpp \ 177 175 UIElements/QT4/QTDialog.cpp \ … … 196 194 ${SHAPESOURCE} \ 197 195 ${DESCRIPTORSOURCE} \ 198 ${HELPERSOURCE} \199 196 bond.cpp \ 200 197 bondgraph.cpp \ … … 228 225 periodentafel.cpp \ 229 226 Plane.cpp \ 230 Space.cpp \231 227 tesselation.cpp \ 232 228 tesselationhelpers.cpp \ … … 234 230 triangleintersectionlist.cpp \ 235 231 UIElements/UIFactory.cpp \ 236 vector.cpp \237 232 vector_ops.cpp \ 238 233 verbose.cpp \ … … 296 291 INCLUDES = -I$(top_srcdir)/src/unittests -I$(top_srcdir)/src/Actions -I$(top_srcdir)/src/UIElements 297 292 298 noinst_LIBRARIES = libmolecuilder .a libgslwrapper.a libmenu.a libparser.a293 noinst_LIBRARIES = libmolecuilderbase.a libmolecuilder.a libgslwrapper.a libmenu.a libparser.a 299 294 bin_PROGRAMS = molecuilder molecuildergui joiner analyzer 295 EXTRA_PROGRAMS = unity 300 296 301 297 molecuilderdir = ${bindir} 302 298 299 libmolecuilderbase_a_SOURCES = ${BASESOURCE} ${BASEHEADER} 303 300 libmolecuilder_a_SOURCES = ${SOURCE} ${HEADER} 304 305 301 libmenu_a_SOURCES = ${UISOURCE} ${UIHEADER} 306 302 libparser_a_SOURCES = ${PARSERSOURCE} ${PARSERHEADER} … … 314 310 molecuilder_SOURCES = ${LEGACYSOURCE} builder.cpp 315 311 molecuilder_SOURCES += $(srcdir)/version.c 316 molecuilder_LDADD = UIElements/libMolecuilderUI.a Actions/libMolecuilderActions.a libmolecuilder .a libparser.a libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB}312 molecuilder_LDADD = UIElements/libMolecuilderUI.a Actions/libMolecuilderActions.a libmolecuilderbase.a libmolecuilder.a libparser.a libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB} 317 313 318 314 #Stuff for building the GUI using QT … … 321 317 molecuildergui_CXXFLAGS = ${QT_CXXFLAGS} ${GLU_CXXFLAGS} -DUSE_GUI_QT 322 318 molecuildergui_LDFLAGS = $(BOOST_LIB) ${QT_LDFLAGS} ${GLU_LDFLAGS} 323 molecuildergui_LDADD = UIElements/libMolecuilderUI.a Actions/libMolecuilderActions.a libmolecuilder .a libparser.a libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB} ${GUI_LIBS}319 molecuildergui_LDADD = UIElements/libMolecuilderUI.a Actions/libMolecuilderActions.a libmolecuilderbase.a libmolecuilder.a libparser.a libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB} ${GUI_LIBS} 324 320 325 321 joiner_SOURCES = joiner.cpp datacreator.cpp parser.cpp datacreator.hpp helpers.hpp parser.hpp periodentafel.hpp 326 joiner_LDADD = libmolecuilder.a $(BOOST_LIB) ${BOOST_THREAD_LIB}322 joiner_LDADD = libmolecuilder.a libmolecuilderbase.a $(BOOST_LIB) ${BOOST_THREAD_LIB} 327 323 328 324 analyzer_SOURCES = analyzer.cpp datacreator.cpp parser.cpp helpers.hpp periodentafel.hpp parser.hpp datacreator.hpp 329 analyzer_LDADD = libmolecuilder.a $(BOOST_LIB) ${BOOST_THREAD_LIB} 325 analyzer_LDADD = libmolecuilder.a libmolecuilderbase.a $(BOOST_LIB) ${BOOST_THREAD_LIB} 326 327 unity_SOURCES = unity.cpp $(srcdir)/version.c 328 unity_LDADD = $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB} 330 329 331 330 #Rules needed for QT4 … … 333 332 # Therfore `%'-rules do not seem to work 334 333 #Quick fix to get it done otherwise 335 ${QTUIMOC_TARGETS}: ${QTUIMOC_HEADER} 334 allmocs.moc.cpp: ${QTUIMOC_HEADER} 335 echo "" > allmocs.moc.cpp;\ 336 336 list='$(QTUIMOC_HEADER)'; for header in $$list; do \ 337 337 echo "Making mocfile for $$header"; \ … … 339 339 $(MOC) $(srcdir)/$$header -o $$target \ 340 340 || eval $$failcom; \ 341 echo "#include \"$$target\"" >> allmocs.moc.cpp; \ 341 342 done; 342 343 343 MOSTLYCLEANFILES = ${QTUIMOC_TARGETS} 344 unity.cpp: ${LINALGSOURCE} ${LINALGHEADER} ${SOURCE} ${HEADER} 345 echo "" > unity.cpp; \ 346 list='$(BASESOURCE)'; for file in $$list; do \ 347 echo "#include \"$(srcdir)/$$file\"" >> unity.cpp; \ 348 done; \ 349 list='$(LINALGSOURCE)'; for file in $$list; do \ 350 echo "#include \"$(srcdir)/$$file\"" >> unity.cpp; \ 351 done; \ 352 list='$(SOURCE)'; for file in $$list; do \ 353 echo "#include \"$(srcdir)/$$file\"" >> unity.cpp; \ 354 done; \ 355 subdirs='$(SUBDIRS)';for directory in $$subdirs; do\ 356 olddir=$$PWD;\ 357 cd $$directory && make unity.cpp;\ 358 cd $$olddir;\ 359 echo "#include \"$$directory/unity.cpp\"" >> unity.cpp;\ 360 done;\ 361 echo "#include \"$(srcdir)/builder.cpp\"" >> unity.cpp; 362 363 MOSTLYCLEANFILES = allmocs.moc.cpp unity.cpp 344 364 345 365 #EXTRA_DIST = ${molecuilder_DATA} -
src/Parser/TremoloParser.cpp
rec149d rf761c4 21 21 22 22 using namespace std; 23 using namespace boost;24 23 25 24 /** -
src/UIElements/Makefile.am
rec149d rf761c4 80 80 CommandLineUI/CommandLineWindow.hpp 81 81 82 82 unity.cpp: 83 echo "" > unity.cpp; \ 84 list='$(UISOURCE)'; for file in $$list; do \ 85 echo "#include \"$(srcdir)/$$file\"" >> unity.cpp; \ 86 done; 87 88 MOSTLYCLEANFILES = unity.cpp -
src/UIElements/TextUI/TextDialog.cpp
rec149d rf761c4 523 523 } 524 524 } 525 return true; 525 526 } 526 527 -
src/UIElements/TextUI/TextWindow.cpp
rec149d rf761c4 25 25 #include "Views/StreamStringView.hpp" 26 26 #include "Views/MethodStringView.hpp" 27 #include "Helpers/MemDebug.hpp"28 27 29 28 #include "defs.hpp" -
src/World.cpp
rec149d rf761c4 32 32 33 33 using namespace std; 34 35 const unsigned int MAX_POOL_FRAGMENTATION=20; 36 const unsigned int MAX_FRAGMENTATION_SKIPS=100; 34 37 35 38 /******************************* getter and setter ************************/ … … 718 721 delete cell_size; 719 722 delete molecules_deprecated; 720 delete periode;721 delete configuration;722 delete Thermostats;723 723 MoleculeSet::iterator molIter; 724 724 for(molIter=molecules.begin();molIter!=molecules.end();++molIter){ … … 731 731 } 732 732 atoms.clear(); 733 delete periode; 734 delete configuration; 735 delete Thermostats; 733 736 } 734 737 -
src/atom.cpp
rec149d rf761c4 19 19 20 20 #include <iomanip> 21 #include <iostream> 21 22 22 23 /************************************* Functions for class atom *************************************/ … … 109 110 }; 110 111 112 bool atom::isFather(const atom *ptr){ 113 return ptr==father; 114 } 115 111 116 /** Checks whether atom is within the given box. 112 117 * \param offset offset to box origin … … 161 166 * \return true - \a *out present, false - \a *out is NULL 162 167 */ 163 bool atom::OutputArrayIndexed(ostream * const out, const int *ElementNo, int *AtomNo, const char *comment) const168 bool atom::OutputArrayIndexed(ostream * const out,const enumeration<const element*> &elementLookup, int *AtomNo, const char *comment) const 164 169 { 165 170 AtomNo[type->Z]++; // increment number 166 171 if (out != NULL) { 167 *out << "Ion_Type" << ElementNo[type->Z] << "_" << AtomNo[type->Z] << "\t" << fixed << setprecision(9) << showpoint; 172 cout << "Looking for atom with element " << *type << endl; 173 ASSERT(elementLookup.there.find(type)!=elementLookup.there.end(),"Type of this atom was not in the formula upon enumeration"); 174 *out << "Ion_Type" << elementLookup.there.find(type)->second << "_" << AtomNo[type->Z] << "\t" << fixed << setprecision(9) << showpoint; 168 175 *out << x[0] << "\t" << x[1] << "\t" << x[2]; 169 176 *out << "\t" << FixedIon; -
src/atom.hpp
rec149d rf761c4 52 52 53 53 bool OutputIndexed(ofstream * const out, const int ElementNo, const int AtomNo, const char *comment = NULL) const; 54 bool OutputArrayIndexed(ostream * const out, const int *ElementNo, int *AtomNo, const char *comment = NULL) const;54 bool OutputArrayIndexed(ostream * const out,const enumeration<const element*>&, int *AtomNo, const char *comment = NULL) const; 55 55 bool OutputXYZLine(ofstream *out) const; 56 56 bool OutputTrajectory(ofstream * const out, const int *ElementNo, int *AtomNo, const int step) const; … … 61 61 62 62 void EqualsFather ( const atom *ptr, const atom **res ) const; 63 bool isFather(const atom *ptr); 63 64 void CorrectFather(); 64 65 atom *GetTrueFather(); -
src/builder.cpp
rec149d rf761c4 110 110 } 111 111 112 void dumpMemory(){ 113 ofstream ost("molecuilder.memdump"); 114 Memory::dumpMemory(ost); 115 } 116 112 117 int main(int argc, char **argv) 113 118 { 114 119 // while we are non interactive, we want to abort from asserts 115 //ASSERT_DO(Assert::Abort); 120 ASSERT_DO(Assert::Abort); 121 ASSERT_HOOK(dumpMemory); 116 122 string line; 117 123 char **Arguments = NULL; … … 127 133 // need to init the history before any action is created 128 134 ActionHistory::init(); 129 130 // In the interactive mode, we can leave the user the choice in case of error131 ASSERT_DO(Assert::Ask);132 135 133 136 // from this moment on, we need to be sure to deeinitialize in the correct order … … 155 158 UIFactory::makeUserInterface("CommandLine"); 156 159 } else { 160 // In the interactive mode, we can leave the user the choice in case of error 161 ASSERT_DO(Assert::Ask); 157 162 #ifdef USE_GUI_QT 158 163 DoLog(0) && (Log() << Verbose(0) << "Setting UI to QT4." << endl); -
src/defs.hpp
rec149d rf761c4 84 84 #define MOLECUILDER_NAME "Molecuilder" 85 85 86 const unsigned int MAX_POOL_FRAGMENTATION=20;87 const unsigned int MAX_FRAGMENTATION_SKIPS=100;86 const extern unsigned int MAX_POOL_FRAGMENTATION; 87 const extern unsigned int MAX_FRAGMENTATION_SKIPS; 88 88 89 89 #endif /*DEFS_HPP_*/ -
src/element.cpp
rec149d rf761c4 26 26 next(NULL), 27 27 sort(NULL), 28 No(-1),29 28 Valence(0), 30 29 NoValenceOrbitals(0) … … 70 69 return string(symbol); 71 70 } 71 72 std::string element::getName() const{ 73 return string(name); 74 } 75 76 std::ostream &operator<<(std::ostream &ost,const element &elem){ 77 ost << elem.getName() << "(" << elem.getNumber() << ")"; 78 return ost; 79 } -
src/element.hpp
rec149d rf761c4 41 41 element *next; //!< next element in list 42 42 int *sort; //!< sorc criteria 43 int No; //!< number of element set on periodentafel::Output()44 43 double Valence; //!< number of valence electrons for this element 45 44 int NoValenceOrbitals; //!< number of valence orbitals, used for determining bond degree in molecule::CreateConnectmatrix() … … 53 52 atomicNumber_t getNumber() const; 54 53 std::string getSymbol() const; 54 std::string getName() const; 55 55 56 56 //> print element entries to screen … … 61 61 }; 62 62 63 std::ostream &operator<<(std::ostream&,const element&); 63 64 64 65 #endif /* ELEMENT_HPP_ */ -
src/helpers.hpp
rec149d rf761c4 194 194 }; 195 195 196 /************ struct to contain simple enumerations ***************/ 197 template <class C> 198 struct enumeration{ 199 enumeration() : max(0) {} 200 enumeration(unsigned int i) : max(i) {} 201 enumeration(const enumeration &src) : 202 there(src.there), 203 back(src.back), 204 max(src.max) 205 {} 206 enumeration &operator=(const enumeration &src){ 207 /* no self-assignment check needed */ 208 there = src.there; 209 back = src.back; 210 max = src.max; 211 return *this; 212 } 213 void add(const C &value){ 214 if(!there.count(value)){ 215 there[value]=max; 216 back[max++]=value; 217 } 218 } 219 unsigned int getMax() const{ 220 return max; 221 } 222 223 map<C,unsigned int> there; 224 map<unsigned int,C> back; 225 private: 226 unsigned int max; 227 }; 228 229 /***** A counter to generate sequential numbers *******************/ 230 struct counter{ 231 inline counter() : count(0){}; 232 inline counter(int i) : count(i){}; 233 inline unsigned int operator()(){ 234 return count++; 235 } 236 private: 237 unsigned int count; 238 }; 239 240 template <class C,class ForwardIterator> 241 enumeration<C> enumerate(ForwardIterator first,ForwardIterator last){ 242 enumeration<C> res; 243 for_each(first,last,bind1st(mem_fun(&enumeration<C>::add),&res)); 244 return res; 245 } 246 196 247 #endif /*HELPERS_HPP_*/ -
src/linearsystemofequations.hpp
rec149d rf761c4 6 6 */ 7 7 8 using namespace std; 8 #ifndef LINEARSYSTEMSOFEQUATIONS_HPP 9 #define LINEARSYSTEMSOFEQUATIONS_HPP 9 10 10 11 /*********************************************** includes ***********************************/ … … 55 56 bool IsSymmetric; 56 57 }; 58 59 #endif /* LINEARSYSTEMSOFEQUATIONS_HPP */ -
src/log.hpp
rec149d rf761c4 12 12 #include "logger.hpp" 13 13 14 class logger *Log();15 class errorLogger *eLog();14 class logger & Log(); 15 class errorLogger & eLog(); 16 16 void setVerbosity(int verbosityLevel); 17 17 bool DoLog(int verbose); -
src/molecule.cpp
rec149d rf761c4 151 151 molecule::const_iterator molecule::erase( const_iterator loc ) 152 152 { 153 OBSERVE; 153 154 molecule::const_iterator iter = loc; 154 155 iter--; … … 156 157 atomIds.erase( atom->getId() ); 157 158 atoms.remove( atom ); 159 formula-=atom->type; 158 160 atom->removeFromMolecule(); 159 161 return iter; … … 162 164 molecule::const_iterator molecule::erase( atom * key ) 163 165 { 166 OBSERVE; 164 167 molecule::const_iterator iter = find(key); 165 168 if (iter != end()){ 166 169 atomIds.erase( key->getId() ); 167 170 atoms.remove( key ); 171 formula-=key->type; 168 172 key->removeFromMolecule(); 169 173 } … … 183 187 pair<molecule::iterator,bool> molecule::insert ( atom * const key ) 184 188 { 189 OBSERVE; 185 190 pair<atomIdSet::iterator,bool> res = atomIds.insert(key->getId()); 186 191 if (res.second) { // push atom if went well 187 192 atoms.push_back(key); 193 formula+=key->type; 188 194 return pair<iterator,bool>(molecule::iterator(--end()),res.second); 189 195 } else { … … 233 239 if (pointer != NULL) { 234 240 atom *walker = pointer->clone(); 241 formula += walker->type; 235 242 walker->setName(pointer->getName()); 236 243 walker->nr = last_atom++; // increase number within molecule … … 619 626 { 620 627 molecule *copy = World::getInstance().createMolecule(); 621 atom *LeftAtom = NULL, *RightAtom = NULL;622 628 623 629 // copy all atoms 624 ActOnCopyWithEachAtom ( &molecule::AddCopyAtom, copy);630 for_each(atoms.begin(),atoms.end(),bind1st(mem_fun(&molecule::AddCopyAtom),copy)); 625 631 626 632 // copy all bonds 627 bond *Binder = NULL;628 bond *NewBond = NULL;629 633 for(molecule::iterator AtomRunner = begin(); AtomRunner != end(); ++AtomRunner) 630 634 for(BondList::iterator BondRunner = (*AtomRunner)->ListOfBonds.begin(); !(*AtomRunner)->ListOfBonds.empty(); BondRunner = (*AtomRunner)->ListOfBonds.begin()) 631 635 if ((*BondRunner)->leftatom == *AtomRunner) { 632 Binder = (*BondRunner);636 bond *Binder = (*BondRunner); 633 637 634 638 // get the pendant atoms of current bond in the copy molecule 635 copy->ActOnAllAtoms( &atom::EqualsFather, (const atom *)Binder->leftatom, (const atom **)&LeftAtom ); 636 copy->ActOnAllAtoms( &atom::EqualsFather, (const atom *)Binder->rightatom, (const atom **)&RightAtom ); 637 638 NewBond = copy->AddBond(LeftAtom, RightAtom, Binder->BondDegree); 639 atomSet::iterator leftiter=find_if(atoms.begin(),atoms.end(),bind2nd(mem_fun(&atom::isFather),Binder->leftatom)); 640 atomSet::iterator rightiter=find_if(atoms.begin(),atoms.end(),bind2nd(mem_fun(&atom::isFather),Binder->rightatom)); 641 ASSERT(leftiter!=atoms.end(),"No original left atom for bondcopy found"); 642 ASSERT(leftiter!=atoms.end(),"No original right atom for bondcopy found"); 643 atom *LeftAtom = *leftiter; 644 atom *RightAtom = *rightiter; 645 646 bond *NewBond = copy->AddBond(LeftAtom, RightAtom, Binder->BondDegree); 639 647 NewBond->Cyclic = Binder->Cyclic; 640 648 if (Binder->Cyclic) … … 643 651 } 644 652 // correct fathers 645 ActOnAllAtoms( &atom::CorrectFather);653 for_each(atoms.begin(),atoms.end(),mem_fun(&atom::CorrectFather)); 646 654 647 655 // copy values … … 852 860 * \param *out output stream 853 861 */ 854 bool molecule::Output(ofstream * const output) 855 { 856 int ElementNo[MAX_ELEMENTS], AtomNo[MAX_ELEMENTS]; 857 858 for (int i=0;i<MAX_ELEMENTS;++i) { 859 AtomNo[i] = 0; 860 ElementNo[i] = 0; 861 } 862 bool molecule::Output(ostream * const output) 863 { 862 864 if (output == NULL) { 863 865 return false; 864 866 } else { 867 int AtomNo[MAX_ELEMENTS]; 868 memset(AtomNo,0,(MAX_ELEMENTS-1)*sizeof(*AtomNo)); 869 enumeration<const element*> elementLookup = formula.enumerateElements(); 870 for(map<const element*,unsigned int>::iterator iter=elementLookup.there.begin(); 871 iter!=elementLookup.there.end();++iter){ 872 cout << "Enumerated element " << *iter->first << " with number " << iter->second << endl; 873 } 865 874 *output << "#Ion_TypeNr._Nr.R[0] R[1] R[2] MoveType (0 MoveIon, 1 FixedIon)" << endl; 866 SetIndexedArrayForEachAtomTo ( ElementNo, &element::Z, &AbsoluteValue, 1); 867 int current=1; 868 for (int i=0;i<MAX_ELEMENTS;++i) { 869 if (ElementNo[i] == 1) 870 ElementNo[i] = current++; 871 } 872 ActOnAllAtoms( &atom::OutputArrayIndexed, (ostream * const) output, (const int *)ElementNo, (int *)AtomNo, (const char *) NULL ); 875 for_each(atoms.begin(),atoms.end(),boost::bind(&atom::OutputArrayIndexed,_1,output,elementLookup,AtomNo,(const char*)0)); 873 876 return true; 874 877 } … … 913 916 { 914 917 DoLog(2) && (Log() << Verbose(2) << endl << "From Contents of ListOfBonds, all non-hydrogen atoms:" << endl); 915 ActOnAllAtoms (&atom::OutputBondOfAtom);918 for_each(atoms.begin(),atoms.end(),mem_fun(&atom::OutputBondOfAtom)); 916 919 DoLog(0) && (Log() << Verbose(0) << endl); 917 920 }; … … 936 939 for (int step=0;step<MDSteps;step++) { 937 940 *output << getAtomCount() << "\n\tCreated by molecuilder, step " << step << ", on " << ctime(&now); 938 ActOnAllAtoms( &atom::OutputTrajectoryXYZ, output, step);941 for_each(atoms.begin(),atoms.end(),boost::bind(&atom::OutputTrajectoryXYZ,_1,output,step)); 939 942 } 940 943 return true; … … 953 956 now = time((time_t *)NULL); // Get the system time and put it into 'now' as 'calender time' 954 957 *output << getAtomCount() << "\n\tCreated by molecuilder on " << ctime(&now); 955 ActOnAllAtoms( &atom::OutputXYZLine, output);958 for_each(atoms.begin(),atoms.end(),bind2nd(mem_fun(&atom::OutputXYZLine),output)); 956 959 return true; 957 960 } else -
src/molecule.hpp
rec149d rf761c4 341 341 342 342 // Output routines. 343 bool Output( ofstream * const output);343 bool Output(std::ostream * const output); 344 344 bool OutputTrajectories(ofstream * const output); 345 345 void OutputListOfBonds() const; -
src/unittests/FormulaUnittest.cpp
rec149d rf761c4 185 185 } 186 186 { 187 Formula formula("CH2(COOH)2"); 188 CPPUNIT_ASSERT_EQUAL(formula["H"],(unsigned int)4); 189 CPPUNIT_ASSERT_EQUAL(formula["O"],(unsigned int)4); 190 CPPUNIT_ASSERT_EQUAL(formula["C"],(unsigned int)3); 191 CPPUNIT_ASSERT_EQUAL(formula["Na"],(unsigned int)0); 192 CPPUNIT_ASSERT_EQUAL(formula["He"],(unsigned int)0); 193 } 194 { 195 Formula formula("K4[Fe(CN)6]"); 196 CPPUNIT_ASSERT_EQUAL(formula["H"],(unsigned int)0); 197 CPPUNIT_ASSERT_EQUAL(formula["O"],(unsigned int)0); 198 CPPUNIT_ASSERT_EQUAL(formula["C"],(unsigned int)6); 199 CPPUNIT_ASSERT_EQUAL(formula["Na"],(unsigned int)0); 200 CPPUNIT_ASSERT_EQUAL(formula["He"],(unsigned int)0); 201 CPPUNIT_ASSERT_EQUAL(formula["K"],(unsigned int)4); 202 CPPUNIT_ASSERT_EQUAL(formula["Fe"],(unsigned int)1); 203 CPPUNIT_ASSERT_EQUAL(formula["N"],(unsigned int)6); 204 } 205 { 206 Formula formula("[CrCl3(H2O)3]"); 207 CPPUNIT_ASSERT_EQUAL(formula["H"],(unsigned int)6); 208 CPPUNIT_ASSERT_EQUAL(formula["O"],(unsigned int)3); 209 CPPUNIT_ASSERT_EQUAL(formula["C"],(unsigned int)0); 210 CPPUNIT_ASSERT_EQUAL(formula["Na"],(unsigned int)0); 211 CPPUNIT_ASSERT_EQUAL(formula["He"],(unsigned int)0); 212 CPPUNIT_ASSERT_EQUAL(formula["Cr"],(unsigned int)1); 213 CPPUNIT_ASSERT_EQUAL(formula["Cl"],(unsigned int)3); 214 } 215 { 216 Formula formula("Mg3[Fe(CN)6]2"); 217 CPPUNIT_ASSERT_EQUAL(formula["H"],(unsigned int)0); 218 CPPUNIT_ASSERT_EQUAL(formula["O"],(unsigned int)0); 219 CPPUNIT_ASSERT_EQUAL(formula["C"],(unsigned int)12); 220 CPPUNIT_ASSERT_EQUAL(formula["Na"],(unsigned int)0); 221 CPPUNIT_ASSERT_EQUAL(formula["He"],(unsigned int)0); 222 CPPUNIT_ASSERT_EQUAL(formula["Mg"],(unsigned int)3); 223 CPPUNIT_ASSERT_EQUAL(formula["Fe"],(unsigned int)2); 224 CPPUNIT_ASSERT_EQUAL(formula["N"],(unsigned int)12); 225 } 226 { 227 Formula formula("Na[Fe((HO2CCH2)2NCH2CH2N(CH2CO2H)2)]"); 228 CPPUNIT_ASSERT_EQUAL(formula["H"],(unsigned int)16); 229 CPPUNIT_ASSERT_EQUAL(formula["O"],(unsigned int)8); 230 CPPUNIT_ASSERT_EQUAL(formula["C"],(unsigned int)10); 231 CPPUNIT_ASSERT_EQUAL(formula["Na"],(unsigned int)1); 232 CPPUNIT_ASSERT_EQUAL(formula["He"],(unsigned int)0); 233 CPPUNIT_ASSERT_EQUAL(formula["Mg"],(unsigned int)0); 234 CPPUNIT_ASSERT_EQUAL(formula["Fe"],(unsigned int)1); 235 CPPUNIT_ASSERT_EQUAL(formula["N"],(unsigned int)2); 236 } 237 { 187 238 CPPUNIT_ASSERT_THROW(Formula formula("74107"),ParseError); 188 239 CPPUNIT_ASSERT_THROW(Formula formula(" "),ParseError); … … 192 243 CPPUNIT_ASSERT_THROW(Formula formula("1NaCl"),ParseError); 193 244 CPPUNIT_ASSERT_THROW(Formula formula("Mag"),ParseError); 245 CPPUNIT_ASSERT_THROW(Formula formula("AgCl)"),ParseError); 246 CPPUNIT_ASSERT_THROW(Formula formula("(Na"),ParseError); 247 CPPUNIT_ASSERT_THROW(Formula formula("(Mag)"),ParseError); 248 CPPUNIT_ASSERT_THROW(Formula formula("MgCl2)"),ParseError); 249 CPPUNIT_ASSERT_THROW(Formula formula("((MgCl2)"),ParseError); 250 CPPUNIT_ASSERT_THROW(Formula formula("(MgCl2))"),ParseError); 251 CPPUNIT_ASSERT_THROW(Formula formula("(MgCl2]"),ParseError); 252 CPPUNIT_ASSERT_THROW(Formula formula("[MgCl2)"),ParseError); 253 CPPUNIT_ASSERT_THROW(Formula formula("N(aCl"),ParseError); 254 CPPUNIT_ASSERT_THROW(Formula formula("Na()Cl"),ParseError); 194 255 } 195 256 -
src/unittests/Makefile.am
rec149d rf761c4 49 49 noinst_PROGRAMS = $(TESTS) TestRunner 50 50 51 GSLLIBS = ../libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB}51 GSLLIBS = ../libgslwrapper.a ../libmolecuilderbase.a $(BOOST_LIB) ${BOOST_THREAD_LIB} 52 52 ALLLIBS = ../libmolecuilder.a ${GSLLIBS} 53 53 PARSERLIBS = ../libparser.a ${ALLLIBS} 54 UILIBS = ../UIElements/libMolecuilderUI.a ../Actions/libMolecuilderActions.a ${ALLLIBS} ${BOOST_PROGRAM_OPTIONS_LIB} 54 55 55 56 TESTSOURCES = \ … … 129 130 130 131 ActionSequenceTest_SOURCES = UnitTestMain.cpp ActionSequenceTest.cpp ActionSequenceTest.hpp $(srcdir)/../version.c 131 ActionSequenceTest_LDADD = ../UIElements/libMolecuilderUI.a ../Actions/libMolecuilderActions.a ../libmolecuilder.a ../libparser.a ../libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB}132 ActionSequenceTest_LDADD = ${UILIBS} 132 133 133 134 ActOnAllUnitTest_SOURCES = UnitTestMain.cpp ../test/ActOnAllTest.hpp ActOnAllUnitTest.cpp ActOnAllUnitTest.hpp … … 195 196 196 197 manipulateAtomsTest_SOURCES = UnitTestMain.cpp manipulateAtomsTest.cpp manipulateAtomsTest.hpp $(srcdir)/../version.c 197 manipulateAtomsTest_LDADD = ../UIElements/libMolecuilderUI.a ../Actions/libMolecuilderActions.a ../libmolecuilder.a ../libparser.a ../libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB}198 manipulateAtomsTest_LDADD = ${UILIBS} 198 199 199 200 MatrixUnittest_SOURCES = UnitTestMain.cpp MatrixUnittest.cpp MatrixUnittest.hpp … … 234 235 235 236 TestRunner_SOURCES = TestRunnerMain.cpp $(srcdir)/../version.c $(TESTSOURCES) $(TESTHEADERS) 236 TestRunner_LDADD = ../UIElements/libMolecuilderUI.a ../Actions/libMolecuilderActions.a ../libmolecuilder.a ../libparser.a ../libgslwrapper.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB}237 TestRunner_LDADD = ../UIElements/libMolecuilderUI.a ../Actions/libMolecuilderActions.a ../libmolecuilder.a ../libparser.a ../libgslwrapper.a ../libmolecuilderbase.a $(BOOST_LIB) ${BOOST_THREAD_LIB} ${BOOST_PROGRAM_OPTIONS_LIB} 237 238 238 239 VectorUnitTest_SOURCES = UnitTestMain.cpp vectorunittest.cpp vectorunittest.hpp
Note:
See TracChangeset
for help on using the changeset viewer.