-- This file is part of SmartEiffel The GNU Eiffel Compiler. -- Copyright (C) 1994-2002 LORIA - INRIA - U.H.P. Nancy 1 - FRANCE -- Dominique COLNET and Suzanne COLLIN - SmartEiffel@loria.fr -- http://SmartEiffel.loria.fr -- SmartEiffel 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, or (at your option) any later -- version. SmartEiffel 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 SmartEiffel; see the file COPYING. If not, -- write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, -- Boston, MA 02111-1307, USA. -- class E_CHECK -- -- Instruction "check ... end;". -- inherit INSTRUCTION creation make feature end_mark_comment: BOOLEAN is true start_position: POSITION is -- Of keyword "check". do if check_invariant /= Void then Result := check_invariant.start_position end end to_runnable(ct: E_TYPE): like Current is do if current_type = Void then current_type := ct if ct.base_class.all_check then all_check := true if check_invariant /= Void then check_invariant := check_invariant.to_runnable(ct) end end Result := Current else !!Result.make(start_position,Void,check_invariant.list) Result := Result.to_runnable(ct) end end stupid_switch(run_time_set: RUN_TIME_SET): BOOLEAN is do Result := true end afd_check is do if all_check and then check_invariant /= Void then check_invariant.afd_check end end safety_check is do check false end end collect_c_tmp is do end compile_to_c is do if all_check and then check_invariant /= Void then check_invariant.compile_to_c end end compile_to_jvm is do if all_check and then check_invariant /= Void then check_invariant.compile_to_jvm(true) code_attribute.opcode_pop end end is_pre_computable: BOOLEAN is do if all_check and then check_invariant /= Void then Result := check_invariant.is_pre_computable else Result := true end end use_current: BOOLEAN is do if all_check and then check_invariant /= Void then Result := check_invariant.use_current end end pretty_print is do if check_invariant /= Void then check_invariant.pretty_print pretty_printer.put_string(once "end;") if pretty_printer.print_end_check then pretty_printer.put_end(once "check") end end end feature {COMPOUND,INSTRUCTION_WITH_COMMENT} verify_scoop(allowed: FORMAL_ARG_LIST) is do if check_invariant /= Void then check_invariant.verify_scoop(allowed) end end feature {NONE} check_invariant: CHECK_INVARIANT current_type: E_TYPE all_check: BOOLEAN make(sp: like start_position; hc: COMMENT; l: ARRAY[ASSERTION]) is require not sp.is_unknown do if hc /= Void or else l /= Void then !!check_invariant.make(sp,hc,l) end end end -- E_CHECK