source: EcnlProtoTool/trunk/asp3_dcre/tecsgen/tecslib/plugin/ATK1TaskPlugin.rb@ 270

Last change on this file since 270 was 270, checked in by coas-nagasima, 7 years ago

mruby版ECNLプロトタイピング・ツールを追加

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-ruby
File size: 7.6 KB
Line 
1# -*- coding: utf-8 -*-
2#
3# TECS Generator Cell-type plugin
4# for TOPPERS Embedded Component System
5#
6# Copyright (C) 2008-2014 by TOPPERS Project TECS-WG
7#--
8# 上記著作権者
9は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
10# ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
11# 変・再é…
12å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
13# (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
14# 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
15# スコード中に含まれていること.
16# (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
17# 用できる形で再é…
18å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
19å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
20# 者
21マニュアルなど)に,上記の著作権表示,この利用条件および下記
22# の無保証規定を掲載すること.
23# (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
24# 用できない形で再é…
25å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
26# と.
27# (a) 再é…
28å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
29マニュアルなど)に,上記の著
30# 作権表示,この利用条件および下記の無保証規定を掲載すること.
31# (b) 再é…
32å¸ƒã®å½¢æ…
33‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
34# 報告すること.
35# (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
36# 害からも,上記著作権者
37およびTOPPERSプロジェクトをå…
38è²¬ã™ã‚‹ã“と.
39# また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
40# 由に基づく請求からも,上記著作権者
41およびTOPPERSプロジェクトを
42# å…
43è²¬ã™ã‚‹ã“と.
44#
45# 本ソフトウェアは,無保証で提供されているものである.上記著作権者
46お
47# よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
48# に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
49# アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
50# の責任を負わない.
51#
52# $Id
53#++
54
55#== celltype プラグインのå…
56±é€šã®è¦ªã‚¯ãƒ©ã‚¹
57class ATK1TaskPlugin < CelltypePlugin
58#@celltype:: Celltype
59#@option:: String :オプション文字列
60
61 #signature:: Celltype シグニチャ(インスタンス)
62 def initialize( celltype, option )
63 super
64 end
65
66 #=== CDL ファイルの生成
67 # typedef, signature, celltype, cell のコードを生成
68 # 重複して生成してはならない
69 # すでに生成されている場合は出力しないこと。
70 # もしくは同名の import により、重複を避けること。
71 #file:: FILE 生成するファイル
72# def gen_cdl_file file
73# end
74
75 def new_cell cell
76# join_list = cell.get_join_list
77# a = join_list.get_item( :resource )
78# if a == nil
79# Generator.error( "resource: must be initialized")
80# elsif ! a.get_rhs.instance_of? Array
81# Generator.error( "resource: initializer must be in format of '{val1, val2 ...}'")
82# end
83 end
84
85 #=== 受け口関数の本体(C言語)を生成する
86 # このメソッドが未定義の場合、ジェネレータは受け口関数のテンプレートを生成する
87 # このメソッドが定義済みの場合、(テンプレートではなく、変更する必
88要のない)セルタイプコードを生成する
89 #file:: FILE 出力å…
90ˆãƒ•ã‚¡ã‚¤ãƒ«
91 #b_singleton:: bool true if singleton
92 #ct_name:: Symbol
93 #global_ct_name:: string
94 #sig_name:: string
95 #ep_name:: string
96 #func_name:: string
97 #func_global_name:: string
98 #func_type:: class derived from Type
99# def gen_ep_func_body( file, b_singleton, ct_name, global_ct_name, sig_name, ep_name, func_name, func_global_name, func_type, params )
100# end
101
102 def gen_factory file
103
104 file2 = CFile.open( "#{$gen}/TASK_tecsgen.oil", "w" )
105
106 extended_task_count = 1
107
108 # TASK
109 @celltype.get_cell_list.each { |cell|
110
111 if cell.is_generate?
112
113 file2.print "\tTASK #{cell.get_name} {\n"
114
115 # AUTOSTART
116 join = cell.get_join_list.get_item( :autoStart )
117 if join then
118 str = join.get_rhs.to_s
119
120 if str == "TRUE" then
121 join2 = cell.get_join_list.get_item( :appMode )
122 if join2 then
123 file2.print "\t\tAUTOSTART = TRUE {\n"
124 delim = ""
125 join2.get_rhs.each { |mode|
126 str = mode.to_s.gsub(/^"(.*)"$/, '\1')
127 file2.print "\t\t\tAPPMODE = #{str};\n"
128 delim = ";"
129 }
130 file2.print "\t\t};\n"
131 else
132 file2.print "\t\tAUTOSTART = TRUE;\n"
133 end
134 elsif str == "FALSE" then
135 file2.print "\t\tAUTOSTART = FALSE;\n"
136 else
137 end
138 end
139
140 # PRIORITY
141 join = cell.get_join_list.get_item( :priority )
142 if join then
143 file2.print "\t\tPRIORITY = #{join.get_rhs.to_s};\n"
144 end
145
146 # ACTIVATION
147 join = cell.get_join_list.get_item( :activation )
148 if join then
149 file2.print "\t\tACTIVATION = #{join.get_rhs.to_s};\n"
150 end
151
152 # SCHEDULE
153 join = cell.get_join_list.get_item( :schedule )
154 if join then
155 str = join.get_rhs.to_s.gsub(/^"(.*)"$/, '\1')
156 file2.print "\t\tSCHEDULE = #{str};\n"
157 end
158
159 # EVENT
160 join = cell.get_join_list.get_item( :event )
161 delim = ""
162 if join then
163 join.get_rhs.each { |evt|
164 str = evt.to_s.gsub(/^"(.*)"$/, '\1')
165 if !(str == "OMISSIBLE")
166 file2.print "\t\tEVENT = #{str};\n"
167 end
168 delim = ";"
169 }
170 join.get_rhs.each { |evt|
171 str = evt.to_s.gsub(/^"(.*)"$/, '\1')
172 if !(str == "OMISSIBLE")
173 cell.set_specified_id( extended_task_count );
174 ++extended_task_count;
175 break
176 end
177 }
178 end
179
180 # RESOURCE
181 join = cell.get_join_list.get_item( :resource )
182 delim = ""
183 if join then
184 join.get_rhs.each { |res|
185 str = res.to_s.gsub(/^"(.*)"$/, '\1')
186 if !(str == "OMISSIBLE")
187 file2.print "\t\tRESOURCE = #{str};\n"
188 end
189 delim = ";"
190 }
191 end
192
193 # MESSAGE
194 join = cell.get_join_list.get_item( :message )
195 delim = ""
196 if join then
197 join.get_rhs.each { |msg|
198 str = msg.to_s.gsub(/^"(.*)"$/, '\1')
199 if !(str == "OMISSIBLE")
200 file2.print "\t\tMESSAGE = #{str};\n"
201 end
202 delim = ";"
203 }
204 end
205
206 # STACKSIZE
207 join = cell.get_join_list.get_item( :stackSize )
208 if join then
209 file2.print "\t\tSTACKSIZE = #{join.get_rhs.to_s};\n"
210 end
211
212 file2.print "\t};\n"
213 file2.print "\n"
214
215 end
216 }
217
218 file2.close
219
220 # 追記するために AppFile を使う(文字コード変換されない)
221 file = AppFile.open( "#{$gen}/tTask_tecsgen.#{$c_suffix}" )
222 file.print "\n/* Generated by ATK1TaskPlugin */\n"
223 @celltype.get_cell_list.each { |cell|
224 if cell.is_generate?
225 name_array = @celltype.get_name_array( cell )
226 file.print <<EOT
227TASK(#{cell.get_name})
228{
229 CELLCB *p_cellcb = #{name_array[8]};
230 cBody_main();
231 terminate();
232}
233
234EOT
235 end
236 }
237
238 file.close
239
240 end
241
242end
243
Note: See TracBrowser for help on using the repository browser.