128 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			128 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef YAPQ_HH
 | |
| #define YAPQ_HH 1
 | |
| 
 | |
| /**
 | |
|    Queries and engines
 | |
| */
 | |
| 
 | |
| /**
 | |
|  * @brief Queries
 | |
|  *
 | |
|  * interface to a YAP Query;
 | |
|  * uses an SWI-like status info internally.
 | |
|  */
 | |
| class YAPQuery: public YAPPredicate {
 | |
|   int q_open;
 | |
|   int q_state;
 | |
|   Term *q_g;
 | |
|   yamop *q_p, *q_cp;
 | |
|   jmp_buf q_env;
 | |
|   int q_flags;
 | |
|   Term vs;
 | |
|   YAP_dogoalinfo q_h;
 | |
|   YAPQuery *oq;
 | |
|   YAPTerm vnames;
 | |
|   void initQuery( Term ts[] );
 | |
|   void initQuery( YAPTerm t[], arity_t arity  );
 | |
| public:
 | |
|   /// main constructor, uses a predicate and an array of terms
 | |
|   ///
 | |
|   /// It is given a YAPPredicate _p_ , and an array of terms that must have at least
 | |
|   /// the same arity as the functor.
 | |
|   YAPQuery(YAPPredicate p, YAPTerm t[]);
 | |
|   /// full constructor,
 | |
|   ///
 | |
|   /// It is given a functor, module, and an array of terms that must have at least
 | |
|   /// the same arity as the functor.
 | |
|   YAPQuery(YAPFunctor f, YAPTerm mod, YAPTerm t[]);
 | |
|   /// functor/term constructor,
 | |
|   ///
 | |
|   /// It is given a functor, and an array of terms that must have at least
 | |
|   /// the same arity as the functor. Works within the current module.
 | |
|   YAPQuery(YAPFunctor f, YAPTerm t[]);
 | |
|   /// string constructor without varnames
 | |
|   ///
 | |
|   /// It is given a string, calls the parser and obtains a Prolog term that should be a callable
 | |
|   /// goal. It does not ask for a list of variables.
 | |
|   inline YAPQuery(const char *s): YAPPredicate(s, q_g, vs)
 | |
|   {
 | |
|     vnames = YAPTerm( vs );
 | |
|     initQuery( q_g );
 | |
|   }
 | |
|  
 | |
|   /// set flags for query execution, currently only for exception handling
 | |
|   void setFlag(int flag) {q_flags |= flag; }
 | |
|   /// reset flags for query execution, currently only for exception handling
 | |
|   void resetFlag(int flag) {q_flags &= ~flag; }
 | |
|   ///  first query
 | |
|   ///
 | |
|   /// actually implemented by calling the next();
 | |
|   inline bool first() { return next(); }
 | |
|   /// ask for the next solution of the current query
 | |
|   /// same call for every solution
 | |
|   bool next();
 | |
|   /// represent the top-goal
 | |
|   char *text();
 | |
|   /// remove alternatives in the current search space, and finish the current query
 | |
|   void cut();
 | |
|   /// finish the current query: undo all bindings.
 | |
|   void close();
 | |
|   /// query variables.
 | |
|   YAPListTerm namedVars();
 | |
| };
 | |
| 
 | |
| // Java support
 | |
| 
 | |
| /// This class implements a callback Prolog-side. It will be inherited by the Java or Python
 | |
| /// class that actually implements the callback.
 | |
| class YAPCallback {
 | |
| public:
 | |
|   virtual ~YAPCallback() { printf("~YAPCallback\n"); }
 | |
|   virtual void run() { __android_log_print(ANDROID_LOG_INFO, __FUNCTION__, "callback");  }
 | |
|   virtual void run(char *s) {  }
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * @brief YAP Engine: takes care of the execution environment
 | |
|  where we can go executing goals.
 | |
|  *
 | |
|  *
 | |
|  */
 | |
| class YAPEngine {
 | |
| private:
 | |
|   YAPCallback *_callback;
 | |
|   YAP_init_args init_args;
 | |
|   YAPError yerror;
 | |
| public:
 | |
|   YAPEngine(char *savedState = (char *)NULL,
 | |
|             size_t stackSize = 0,
 | |
|             size_t trailSize = 0,
 | |
|             size_t maxStackSize = 0,
 | |
|             size_t maxTrailSize = 0,
 | |
|             char *libDir = (char *)NULL,
 | |
|             char *bootFile = (char *)NULL,
 | |
|             char *goal = (char *)NULL,
 | |
|             char *topLevel = (char *)NULL,
 | |
|             bool script = FALSE,
 | |
|             bool fastBoot = FALSE,
 | |
|             YAPCallback *callback=(YAPCallback *)NULL);  /// construct a new engine, including aaccess to callbacks
 | |
|   /// kill engine
 | |
|   ~YAPEngine() { delYAPCallback(); }
 | |
|   /// remove current callback
 | |
|   void delYAPCallback() { _callback = 0; }
 | |
|   /// set a new callback
 | |
|   void setYAPCallback(YAPCallback *cb) { delYAPCallback(); _callback = cb; }
 | |
|   /// execute the callback.
 | |
|   void run() { if (_callback) _callback->run(); }
 | |
|   /// execute the callback with a text argument.
 | |
|   void run( char *s) {  if (_callback) _callback->run(s); }
 | |
|   /// execute the callback with a text argument.
 | |
|   YAPError hasError( ) {  return yerror; }
 | |
|   /// build a query on the engine
 | |
|   YAPQuery *query( char *s );
 | |
|   /// current module for the engine
 | |
|   YAPModule currentModule( ) { return YAPModule( ) ; }
 | |
| };
 | |
| 
 | |
| #endif /* YAPQ_HH */
 |