File: example2.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 (40 lines) | stat: -rw-r--r-- 892 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
class EXAMPLE2
--
-- Actually, agents are available for all kinds of COLLECTION (i.e. ARRAY,
-- FIXED_ARRAY, LINKED_LIST, TWO_WAY_LINKED_LIST), but also for class SET
-- as well as for class DICTIONARY.
--

creation make

feature

   make is
      local
	 my_collection: COLLECTION[STRING]
         my_list: LINKED_LIST[STRING]; my_set: SET[STRING]
      do
	 my_collection := <<"Benedicte","Lucien","Marie">>

	 create my_list.make
	 -- Using an agent to fill `my_list' using `my_collection':
	 my_collection.do_all(agent my_list.add_last(?))

	 create my_set.make
	 -- Using an agent to fill `my_set' with `my_list':
	 my_list.do_all(agent my_set.add(?))

	 -- Using an agent to print `my_set':
	 my_set.do_all(agent print_item(?))
      end

feature {NONE}

   print_item(item: STRING) is
      do
	 std_output.put_string(item)
	 std_output.put_character('%N')
      end

end -- EXAMPLE2