aiml.h

来自「AIML的实现」· C头文件 代码 · 共 174 行

H
174
字号
#ifndef REBECCA_FRAMEWORK_AIML_H#define REBECCA_FRAMEWORK_AIML_H/* * RebeccaAIML, Artificial Intelligence Markup Language  * C++ api and engine. * * Copyright (C) 2005 Frank Hassanabad * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA *///Rebecca includes#include <rebecca/framework/Tag.h>#include <rebecca/framework/Topic.h>/* Disable Windows VC 7.x warning about  * shared_ptr needing dll-interface and * about it ignoring the throw specification */#ifdef _WIN32#    pragma warning ( push )#    pragma warning( disable : 4251 )#    pragma warning( disable : 4290 )#endifnamespace rebecca{namespace framework{namespace impl{/* * Forward declarations *//** * The private implementation in which * you cannot get access to. * * This class holds the private methods * and private attributes of this class.  This  * makes ABI (Application Binary Interface) more * resilient to change. See the private implementation * idiom on the internet for more information about this. */class AIMLImpl;class GraphBuilderFramework;/** * AIML class that represents the  * AIML XML tag "aiml".   * * Every time a XML Tag of AIML is  * encountered, an instance of  * this class will be created.  All text * inbetween the begin and end tag, all * attributes, and all inner Tags will * go through methods of this class. */class REBECCA_EXPORT AIML : public Tag{		public:		/** 		 * Initalizes the private 		 * implementation (m_pimpl) data and 		 * sets the private implementation 		 * with a reference to the 		 * GraphBuilderFramework.           *		 * Also creates a default Topic object which 		 * is important for AIML::handleInnerTag		 *		 * \param builder A reference 		 * to the graph builder framework that 		 * can be used to set and get information 		 * from the AIML engine.		 *		 * \exception InternalProgrammerErrorException is thrown 		 * only if the error is so grave that the entire AIML 		 * engine has to be shut down.		 */		AIML(GraphBuilderFramework &builder) throw(InternalProgrammerErrorException &);				/**		 * Sets its attribute of "version"         *		 * \param name The name of the AIML XML attribute		 *		 * \param value The value of the AIML XML attribute         *		 * \exception InternalProgrammerErrorException is thrown 		 * only if the error is so grave that the entire AIML 		 * engine has to be shut down.		 */		virtual void setAttribute(const StringPimpl &name, const StringPimpl &value) 			throw(InternalProgrammerErrorException &);				/**		 * Calls its internal default Topic Object's Topic::handleInnerTag() 		 * with this AIML XML tag.		 *		 * Whenever the AIML Tag encounters an inner AIML XML Tag it's always either a Category		 * Tag or a Topic Tag.  If it is a Category Tag it sends the Tag to its internal default 		 * Topic Tag object by calling its internal Topic Tag's handleInnerTag.  If it is a 		 * Topic Tag it safetly ignores it.  The default Topic Tag is a Topic Tag with its topic 		 * set to "*".  When a Topic is not specified in AIML XML, it is to default to "*".  When a 		 * Topic is not specified, this handleInnerTag gets called with a Category Tag object which 		 * in turn calls the internal default Topic Tag with the Category Tag object.  When a Topic 		 * is specified AIML's handleInnerTag gets called with a Topic Object and safetly ignores 		 * it since it does not need to do anything with it.		 *		 * \param tag The Category Tag or Topic Tag		 *         * \exception InternalProgrammerErrorException is thrown 		 * only if the error is so grave that the entire AIML 		 * engine has to be shut down.		 */		virtual void handleInnerTag(const shared_ptr<Tag> &tag) 			throw(InternalProgrammerErrorException &);		/** 		 * Default virtual destructor.  Destroys the private implementation		 * (m_pimpl) data.		 */		virtual ~AIML();	private:	   /**		* The private implementation in which		* you cannot get access to.		*		* This shared_ptr holds the private methods 		* and private member variables of this class.  This 		* makes ABI (Application Binary Interface) more		* resilient to change. See the private implementation		* idiom on the internet for more information about this.		*/		shared_ptr<AIMLImpl> m_pimpl;};} //end of namespace impl//Expose just the class name to the framework namespaceusing rebecca::framework::impl::AIML;} //end of namespace framework } //end of namespace rebecca#ifdef _WIN32#    pragma warning ( pop )#endif#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?