00001 /*---------------------------------------------------------------------------*\ 00002 ========= | 00003 \\ / F ield | OpenFOAM: The Open Source CFD Toolbox 00004 \\ / O peration | 00005 \\ / A nd | Copyright (C) 2008-2010 OpenCFD Ltd. 00006 \\/ M anipulation | 00007 ------------------------------------------------------------------------------- 00008 License 00009 This file is part of OpenFOAM. 00010 00011 OpenFOAM is free software: you can redistribute it and/or modify it 00012 under the terms of the GNU General Public License as published by 00013 the Free Software Foundation, either version 3 of the License, or 00014 (at your option) any later version. 00015 00016 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT 00017 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00018 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 00019 for more details. 00020 00021 You should have received a copy of the GNU General Public License 00022 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>. 00023 00024 \*---------------------------------------------------------------------------*/ 00025 00026 #include <potential/pairPotential.H> 00027 00028 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00029 00030 namespace Foam 00031 { 00032 00033 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00034 00035 autoPtr<pairPotential> pairPotential::New 00036 ( 00037 const word& name, 00038 const dictionary& pairPotentialProperties 00039 ) 00040 { 00041 word pairPotentialTypeName(pairPotentialProperties.lookup("pairPotential")); 00042 00043 Info<< nl << "Selecting intermolecular pair potential " 00044 << pairPotentialTypeName << " for " 00045 << name << " interaction." << endl; 00046 00047 dictionaryConstructorTable::iterator cstrIter = 00048 dictionaryConstructorTablePtr_->find(pairPotentialTypeName); 00049 00050 if (cstrIter == dictionaryConstructorTablePtr_->end()) 00051 { 00052 FatalErrorIn 00053 ( 00054 "pairPotential::New()" 00055 ) << "Unknown pairPotential type " 00056 << pairPotentialTypeName << nl << nl 00057 << "Valid pairPotentials are: " << nl 00058 << dictionaryConstructorTablePtr_->sortedToc() 00059 << exit(FatalError); 00060 } 00061 00062 return autoPtr<pairPotential> 00063 (cstrIter()(name, pairPotentialProperties)); 00064 } 00065 00066 00067 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // 00068 00069 } // End namespace Foam 00070 00071 // ************************ vim: set sw=4 sts=4 et: ************************ //