/************************************************************************************* * Copyright (C) 2009 by Aleix Pol * * * * This program is free software; you can redistribute it and/or * * modify it under the terms of the GNU General Public License * * as published by the Free Software Foundation; either version 2 * * of the License, or (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the Free Software * * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * *************************************************************************************/ #include "functionfactory.h" using Analitza::Expression; using Analitza::Variables; FunctionFactory* FunctionFactory::m_self=0; bool FunctionFactory::contains(const FunctionFactory::Id& bvars) const { return m_items.contains(bvars.join("|")); } FunctionImpl* FunctionFactory::item(const Id& bvars, const Expression& exp, Variables* v) const { return m_items[bvars.join("|")](exp, v); } bool FunctionFactory::registerFunction(const FunctionFactory::Id& bvars, registerFunc_fn f) { Q_ASSERT(!contains(bvars)); m_items[bvars.join("|")]=f; return true; } FunctionFactory* FunctionFactory::self() { if(!m_self) m_self=new FunctionFactory; return m_self; }