* sim/ucsim/cmd.src/error.cc, sim/ucsim/cmd.src/errorcl.h,
[fw/sdcc] / sim / ucsim / errorcl.h
index 99f83e81320fcc35542f5271ff71ea8e34e9659b..a061b3a311e6d0c07de6704fff515bc8637ae04c 100644 (file)
@@ -7,22 +7,24 @@
  *
  */
 
-/* This file is part of microcontroller simulator: ucsim.
-
-UCSIM 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.
-
-UCSIM 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 UCSIM; see the file COPYING.  If not, write to the Free
-Software Foundation, 59 Temple Place - Suite 330, Boston, MA
-02111-1307, USA. */
+/*
+  This file is part of microcontroller simulator: ucsim.
+
+  UCSIM 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.
+
+  UCSIM 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 UCSIM; see the file COPYING.  If not, write to the Free
+  Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+  02111-1307, USA.
+*/
 /*@1@*/
 
 #ifndef ERRORCL_HEADER
@@ -32,22 +34,63 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
 #include "pobjcl.h"
 #include "stypes.h"
 
-// cmd.src
-//#include "newcmdcl.h"
+extern struct id_element error_on_off_names[];
+
+enum error_on_off {
+  ERROR_PARENT,
+  ERROR_ON,
+  ERROR_OFF
+};
+
+const int err_stop= (err_unknown|err_error);
 
+extern class cl_list *registered_errors;
+
+class cl_error_class: public cl_base
+{
+protected:
+  enum error_type type;
+  //char *name;
+  enum error_on_off on;
+public:
+  cl_error_class(enum error_type typ, char *aname,
+                enum error_on_off be_on= ERROR_PARENT);
+  cl_error_class(enum error_type typ, char *aname,
+                class cl_error_class *parent,
+                enum error_on_off be_on= ERROR_PARENT);
+  
+  enum error_on_off get_on(void) { return(on); }
+  void set_on(enum error_on_off val);
+  bool is_on(void);
+  enum error_type get_type(void);
+  char *get_type_name(void);
+  //char *get_name(void);
+};
 
 class cl_commander; //forward
 
 class cl_error: public cl_base
 {
+private:
+  static class cl_error_class *error_class_base;
+protected:
+  class cl_error_class *classification;
 public:
   bool inst;   // Occured during instruction execution
   t_addr PC;   // Address of the instruction
 public:
   cl_error(void);
   virtual ~cl_error(void);
+  virtual int init(void);
+
+public:
+  virtual enum error_type get_type(void);
+  virtual enum error_on_off get_on(void);
+  virtual bool is_on(void);
+  virtual class cl_error_class *get_class(void) { return(classification); }
 
   virtual void print(class cl_commander *c);
+  virtual char *get_type_name();
 };