File: e_retry.e

package info (click to toggle)
smarteiffel 1.1-11
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 12,288 kB
  • ctags: 40,785
  • sloc: ansic: 35,791; lisp: 4,036; sh: 1,783; java: 895; ruby: 613; python: 209; makefile: 115; csh: 78; cpp: 50
file content (128 lines) | stat: -rw-r--r-- 3,190 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
-- This file is part of SmartEiffel The GNU Eiffel Compiler Tools and Libraries
--
-- 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.
--
-- Copyright(C) 1994-2002: INRIA - LORIA (INRIA Lorraine) - ESIAL U.H.P.
--			   - University of Nancy 1 - FRANCE
-- Copyright(C) 2003:      INRIA - LORIA (INRIA Lorraine) - I.U.T. Charlemagne
--			   - University of Nancy 2 - FRANCE
--
--		 Dominique COLNET, Suzanne COLLIN, Olivier ZENDRA,
--			   Philippe RIBET, Cyril ADRIAN
--
-- http://SmartEiffel.loria.fr - SmartEiffel@loria.fr
--
class E_RETRY
   --
   -- To store instruction "retry" for exception handling.
   --

inherit INSTRUCTION

creation make

feature

   start_position: POSITION

   side_effect_free: BOOLEAN is False
      
   end_mark_comment: BOOLEAN is False

   once_pre_computable: BOOLEAN is False

   use_current: BOOLEAN is False

   afd_check is
      do
      end

   safety_check is
      do
      end

   simplify_2(container: COMPOUND; index: INTEGER) is
      do
      end

   collect_c_tmp is
      do
      end

   compile_to_c is
      do
         if ace.no_check then
            cpp.put_string(once "fd.assertion_flag=1;%Nfree_exception_frames();%N")
         end
         cpp.put_string(once "goto retry_tag;%N")
      end

   compile_to_jvm is
      do
         code_attribute.opcode_goto_backward( jvm.current_frame.jvm_try_begin )
      end

   to_runnable(ct: E_TYPE): like Current is
      local
         rf: RUN_FEATURE
      do
         rf := smart_eiffel.top_rf
         if run_feature = Void then
            run_feature := rf
            Result := Current
         elseif run_feature = rf then
            Result := Current
         else
            !!Result.make(start_position)
            Result := Result.to_runnable(ct)
         end
      end

   stupid_switch(run_time_set: RUN_TIME_SET): BOOLEAN is
      do
         Result := True
      end

   pretty_print is
      do
         pretty_printer.put_string(once "retry")
         if pretty_printer.semi_colon_flag then
            pretty_printer.put_character(';')
         end
      end

feature {COMPOUND,INSTRUCTION_WITH_COMMENT}

   verify_scoop(allowed: FORMAL_ARG_LIST) is
      do
      end

feature {E_RETRY_VISITOR}

   accept(visitor: E_RETRY_VISITOR) is
      do
         visitor.visit_e_retry(Current)
      end

feature {NONE}

   run_feature: RUN_FEATURE
         -- Corresponding one when runnable.

   make(sp: like start_position) is
      do
         start_position := sp
      end

end -- E_RETRY