File: e_procedure.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 (113 lines) | stat: -rw-r--r-- 3,691 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
-- 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_PROCEDURE

inherit EFFECTIVE_ROUTINE rename make_effective_routine as make end

creation make, attribute_writer

feature

   result_type: E_TYPE is
      do
      end

   to_run_feature(t: E_TYPE; fn: FEATURE_NAME): RUN_FEATURE_3 is
      do
	 !!Result.make(t,fn,Current)
      end

feature {E_PROCEDURE_VISITOR}

   accept(visitor: E_PROCEDURE_VISITOR) is
      do
         visitor.visit_e_procedure(Current)
      end

feature {BASE_CLASS}

   a_default_rescue(rc: RUN_CLASS; fn: FEATURE_NAME): RUN_FEATURE_3 is
         -- Non Void when the corresponding `default_rescue' really
         -- make something.
      local
         non_empty_default_rescue: BOOLEAN
      do
         if local_vars /= Void then
            non_empty_default_rescue := true
         elseif routine_body /= Void then
            non_empty_default_rescue := not routine_body.side_effect_free
         end
         if non_empty_default_rescue then
	    Result ?= rc.at(fn)
	    if Result = Void then
	       Result := to_run_feature(rc.current_type,fn)
	    end
	 end
      end

feature {NONE}

   attribute_writer(bc: like base_class
		    set_attribute_name, attribute_name: FEATURE_NAME) is
	 -- Allow the creation of an implicit procedure to write an
	 -- attribute written in class `bc'. As an example, this routine
	 -- is used to create `set_first', `set_second', ... TUPLE implicit
	 -- attributes writers.
      local
	 sp: POSITION; fnl: like names; a1: ARGUMENT_NAME1
	 a2: ARGUMENT_NAME2; d1: DECLARATION_1
	 ad: ARRAY[DECLARATION]; formal_arg_list: like arguments
	 assignment: ASSIGNMENT; body: like routine_body
      do
	 sp.set_in(bc)
	 base_class := bc
	 !!fnl.make_1(set_attribute_name)
	 !!a1.make(sp,as_item)
	 !!d1.make(a1,attribute_name.result_type)
	 ad := <<d1>>
	 !!formal_arg_list.make(ad)
	 !!a2.refer_to(sp,formal_arg_list,1)
	 !!assignment.make(attribute_name,a2)
	 !!body.make_1(Void,assignment)
	 make(fnl,formal_arg_list,Void,Void,Void,Void,body)
	 !!clients.omitted
      end

   try_to_undefine_aux(fn: FEATURE_NAME
                       bc: BASE_CLASS): DEFERRED_ROUTINE is
      do
         !DEFERRED_PROCEDURE!Result.from_effective(fn,arguments,
                                                   require_assertion,
                                                   ensure_assertion,
                                                   bc)
      end

   pretty_print_once_or_do is
      do
         pretty_printer.keyword(fz_do)
      end

end -- E_PROCEDURE