source: dev/trunk/abdev/BasicCompiler_Common/include/Procedure.h@ 350

Last change on this file since 350 was 350, checked in by dai_9181, 17 years ago

インターフェイスを実装

File size: 11.9 KB
Line 
1#pragma once
2
3#include <Hashmap.h>
4#include <option.h>
5#include <Program.h>
6#include <Class.h>
7#include <Method.h>
8#include <Procedure.h>
9#include <Parameter.h>
10#include <Variable.h>
11#include <CodeGenerator.h>
12#include <Source.h>
13
14class CClass;
15class CMethod;
16
17class Procedure : public Symbol
18{
19public:
20 // 種類
21 enum Kind{
22 Sub,
23 Function,
24 };
25
26private:
27 Kind kind;
28
29 bool isCdecl;
30 mutable bool isUsing;
31
32protected:
33
34 // パラメータ
35 Parameters params;
36
37 // 戻り値の型
38 Type returnType;
39
40 // ソースコードの位置
41 int codePos;
42
43 // XMLシリアライズ用
44private:
45 friend class boost::serialization::access;
46 template<class Archive> void serialize(Archive& ar, const unsigned int version)
47 {
48 trace_for_serialize( "serializing - Procedure" );
49
50 ar & BOOST_SERIALIZATION_BASE_OBJECT_NVP( Symbol );
51 ar & BOOST_SERIALIZATION_NVP( kind );
52 ar & BOOST_SERIALIZATION_NVP( isCdecl );
53 ar & BOOST_SERIALIZATION_NVP( isUsing );
54 ar & BOOST_SERIALIZATION_NVP( params );
55 ar & BOOST_SERIALIZATION_NVP( returnType );
56 ar & BOOST_SERIALIZATION_NVP( codePos );
57 }
58
59public:
60 Procedure( const NamespaceScopes &namespaceScopes, const string &name, Kind kind, bool isCdecl )
61 : Symbol( namespaceScopes, name )
62 , kind( kind )
63 , isCdecl( isCdecl )
64 , isUsing( false )
65 , codePos( -1 )
66 {
67 }
68 Procedure()
69 {
70 }
71 ~Procedure(){
72 BOOST_FOREACH( Parameter *pParam, params ){
73 delete pParam;
74 }
75 }
76
77 bool IsSub() const
78 {
79 return ( kind == Sub );
80 }
81 bool IsFunction() const
82 {
83 return ( kind == Function );
84 }
85
86 bool IsCdecl() const
87 {
88 return isCdecl;
89 }
90 void Using() const
91 {
92 isUsing = true;
93 }
94 bool IsUsing() const
95 {
96 return isUsing;
97 }
98
99 int GetCodePos() const
100 {
101 return codePos;
102 }
103
104 const Parameters &Params() const
105 {
106 return params;
107 }
108 const Type &ReturnType() const
109 {
110 return returnType;
111 }
112};
113
114class UserProc : public Procedure, public Jenga::Common::ObjectInHashmap<UserProc>
115{
116public:
117 string _paramStr;
118
119private:
120 NamespaceScopesCollection importedNamespaces;
121
122 // 親クラスと対応するメソッド
123 const CClass *pParentClass;
124 CMethod *pMethod;
125
126 bool isMacro;
127
128 // パラメータの追加情報
129 int secondParmNum;
130 Parameters realParams;
131 int realSecondParmNum;
132
133 // 各種フラグ
134 bool isExport;
135 mutable bool isSystem;
136 mutable bool isAutoGeneration;
137 mutable bool isCompiled;
138
139 mutable DWORD beginOpAddress;
140 mutable DWORD endOpAddress;
141
142 // ローカル変数
143 mutable Variables localVars;
144
145 // 識別ID
146 int id;
147
148 // ネイティブコード
149 NativeCode nativeCode;
150
151 // XMLシリアライズ用
152private:
153 friend class boost::serialization::access;
154 template<class Archive> void serialize(Archive& ar, const unsigned int version)
155 {
156 trace_for_serialize( "serializing - UserProc" );
157
158 ar & BOOST_SERIALIZATION_BASE_OBJECT_NVP( Procedure );
159 ar & BOOST_SERIALIZATION_NVP( _paramStr );
160 ar & BOOST_SERIALIZATION_NVP( importedNamespaces );
161 ar & boost::serialization::make_nvp("pParentClass", const_cast<CClass *&>(pParentClass) );
162 ar & BOOST_SERIALIZATION_NVP( pMethod );
163 ar & BOOST_SERIALIZATION_NVP( isMacro );
164 ar & BOOST_SERIALIZATION_NVP( secondParmNum );
165 ar & BOOST_SERIALIZATION_NVP( realParams );
166 ar & BOOST_SERIALIZATION_NVP( realSecondParmNum );
167 ar & BOOST_SERIALIZATION_NVP( isExport );
168 ar & BOOST_SERIALIZATION_NVP( isSystem );
169 ar & BOOST_SERIALIZATION_NVP( isAutoGeneration );
170 ar & BOOST_SERIALIZATION_NVP( isCompiled );
171 ar & BOOST_SERIALIZATION_NVP( beginOpAddress );
172 ar & BOOST_SERIALIZATION_NVP( endOpAddress );
173 ar & BOOST_SERIALIZATION_NVP( localVars );
174 ar & BOOST_SERIALIZATION_NVP( id );
175 ar & BOOST_SERIALIZATION_NVP( nativeCode );
176 }
177
178public:
179
180 UserProc( const NamespaceScopes &namespaceScopes, const NamespaceScopesCollection &importedNamespaces, const string &name, Kind kind, bool isMacro, bool isCdecl, bool isExport, int id )
181 : Procedure( namespaceScopes, name, kind, isCdecl )
182 , importedNamespaces( importedNamespaces )
183 , pParentClass( NULL )
184 , pMethod( NULL )
185 , isMacro( isMacro )
186 , isExport( isExport )
187 , isSystem( false )
188 , isAutoGeneration( false )
189 , isCompiled( false )
190 , beginOpAddress( 0 )
191 , endOpAddress( 0 )
192 , id( id )
193 {
194 }
195 UserProc()
196 {
197 }
198 ~UserProc()
199 {
200 BOOST_FOREACH( Parameter *pParam, realParams ){
201 delete pParam;
202 }
203 }
204
205 virtual const std::string &GetKeyName() const
206 {
207 return GetName();
208 }
209
210 virtual bool IsDuplication( const UserProc *pUserProc ) const
211 {
212 if( this->GetParentClassPtr() == pUserProc->GetParentClassPtr() // 親クラスが等しい
213 && pUserProc->IsEqualSymbol( *this ) // 名前空間及び名前が等しい
214 && this->Params().Equals( pUserProc->Params() ) // パラメータが等しい
215 && this->returnType.Equals( pUserProc->returnType ) ) // 戻り値が等しい
216 {
217 return true;
218 }
219 return false;
220 }
221
222 bool IsMacro() const
223 {
224 return isMacro;
225 }
226
227 int GetSecondParmNum() const
228 {
229 return secondParmNum;
230 }
231 const Parameters &RealParams() const
232 {
233 return realParams;
234 }
235 int GetRealSecondParmNum() const
236 {
237 return realSecondParmNum;
238 }
239
240 void ExportOff(){
241 isExport = false;
242 }
243 bool IsExport() const
244 {
245 return isExport;
246 }
247 void ThisIsSystemProc() const
248 {
249 isSystem = true;
250 }
251 bool IsSystem() const
252 {
253 return isSystem;
254 }
255 void ThisIsAutoGenerationProc() const
256 {
257 isAutoGeneration = true;
258 }
259 bool IsAutoGeneration() const
260 {
261 return isAutoGeneration;
262 }
263 void CompleteCompile() const
264 {
265 isCompiled = true;
266 }
267 void KillCompileStatus() const
268 {
269 isCompiled = false;
270 }
271 bool IsCompiled() const
272 {
273 return isCompiled;
274 }
275 bool IsDestructor() const
276 {
277 return ( GetName()[0] == '~' );
278 }
279
280 // バイナリコード位置とサイズ
281 DWORD GetBeginOpAddress() const
282 {
283 return beginOpAddress;
284 }
285 void SetBeginOpAddress( DWORD beginOpAddress ) const
286 {
287 this->beginOpAddress = beginOpAddress;
288 }
289 DWORD GetEndOpAddress() const
290 {
291 return endOpAddress;
292 }
293 void SetEndOpAddress( DWORD endOpAddress ) const
294 {
295 this->endOpAddress = endOpAddress;
296 }
297 int GetCodeSize() const
298 {
299 return endOpAddress - beginOpAddress;
300 }
301
302 virtual const NamespaceScopes &GetNamespaceScopes() const;
303 const NamespaceScopesCollection &GetImportedNamespaces() const;
304
305 Variables &GetLocalVars() const
306 {
307 return localVars;
308 }
309
310 int GetId() const
311 {
312 return id;
313 }
314
315 const NativeCode &GetNativeCode() const
316 {
317 return nativeCode;
318 }
319 NativeCode &GetNativeCode()
320 {
321 return nativeCode;
322 }
323
324 std::string GetFullName() const;
325 bool IsCastOperator() const;
326
327 bool IsVirtual() const;
328
329 void SetParentClass( const CClass *pParentClass ){
330 this->pParentClass = pParentClass;
331 }
332 const CClass *GetParentClassPtr() const
333 {
334 return pParentClass;
335 }
336 const CClass &GetParentClass() const
337 {
338 return *pParentClass;
339 }
340 bool HasParentClass() const
341 {
342 return ( pParentClass != NULL );
343 }
344 bool IsGlobalProcedure() const
345 {
346 return ( pParentClass == NULL );
347 }
348 void SetMethod( CMethod *pMethod ){
349 this->pMethod = pMethod;
350 }
351 const CMethod &GetMethod() const;
352
353 bool SetParamsAndReturnType( const char *sourceOfParams, int nowLine, bool isStatic );
354
355
356
357 /////////////////////////////////////////////////////////////////
358 // コンパイル中の関数を管理
359 /////////////////////////////////////////////////////////////////
360private:
361 static const UserProc *pCompilingUserProc;
362public:
363 static void CompileStartForGlobalArea(){
364 pCompilingUserProc = NULL;
365 }
366 static void CompileStartForUserProc( const UserProc *pUserProc ){
367 pCompilingUserProc = pUserProc;
368 }
369 static bool IsGlobalAreaCompiling(){
370 return ( pCompilingUserProc == NULL );
371 }
372 static bool IsLocalAreaCompiling(){
373 return ( pCompilingUserProc != NULL );
374 }
375 static const UserProc &CompilingUserProc(){
376 return *pCompilingUserProc;
377 }
378};
379
380class UserProcs : public Jenga::Common::Hashmap<UserProc>
381{
382 std::vector<std::string> macroNames;
383
384 // XMLシリアライズ用
385private:
386 friend class boost::serialization::access;
387 template<class Archive> void serialize(Archive& ar, const unsigned int version)
388 {
389 trace_for_serialize( "serializing - UserProcs" );
390
391 ar & boost::serialization::make_nvp("Hashmap_UserProcImpl",
392 boost::serialization::base_object<Jenga::Common::Hashmap<UserProc>>(*this));
393 ar & BOOST_SERIALIZATION_NVP( macroNames );
394 }
395
396
397public:
398 UserProcs()
399 {
400 }
401 ~UserProcs()
402 {
403 }
404
405 bool Insert( UserProc *pUserProc, int nowLine );
406
407 UserProc *Add( const NamespaceScopes &namespaceScopes, const NamespaceScopesCollection &importedNamespaces, char *buffer,int nowLine,bool isVirtual,CClass *pobj_c, bool isStatic);
408
409 void EnumGlobalProcs( const char *simpleName, const char *localName, std::vector<const UserProc *> &subs );
410};
411
412class DllProc : public Procedure, public Jenga::Common::ObjectInHashmap<DllProc>
413{
414 string dllFileName;
415 string alias;
416 int lookupAddress;
417
418 // XMLシリアライズ用
419private:
420 friend class boost::serialization::access;
421 template<class Archive> void serialize(Archive& ar, const unsigned int version)
422 {
423 trace_for_serialize( "serializing - DllProc" );
424
425 ar & BOOST_SERIALIZATION_BASE_OBJECT_NVP( Procedure );
426 ar & BOOST_SERIALIZATION_NVP( dllFileName );
427 ar & BOOST_SERIALIZATION_NVP( alias );
428 ar & BOOST_SERIALIZATION_NVP( lookupAddress );
429 }
430
431public:
432 DllProc( const NamespaceScopes &namespaceScopes, const string &name, Kind kind, bool isCdecl, const string &dllFileName, const string &alias )
433 : Procedure( namespaceScopes, name, kind, isCdecl )
434 , dllFileName( dllFileName )
435 , alias( alias )
436 , lookupAddress( 0 )
437 {
438 }
439 DllProc()
440 {
441 }
442 ~DllProc()
443 {
444 }
445
446 virtual const std::string &GetKeyName() const
447 {
448 return GetName();
449 }
450
451 virtual bool IsDuplication( const DllProc *pDllProc ) const
452 {
453 if( pDllProc->IsEqualSymbol( *this )
454 && this->Params().Equals( pDllProc->Params() ) )
455 {
456 return true;
457 }
458 return false;
459 }
460
461 const string &GetDllFileName() const
462 {
463 return dllFileName;
464 }
465 const string &GetAlias() const
466 {
467 return alias;
468 }
469
470 void SetLookupAddress( int lookupAddress ){
471 this->lookupAddress = lookupAddress;
472 }
473 int GetLookupAddress() const
474 {
475 return lookupAddress;
476 }
477
478 bool SetParamsAndReturnType( const char *sourceOfParams, int nowLine );
479};
480class DllProcs : public Jenga::Common::Hashmap<DllProc>
481{
482 // XMLシリアライズ用
483private:
484 friend class boost::serialization::access;
485 template<class Archive> void serialize(Archive& ar, const unsigned int version)
486 {
487 trace_for_serialize( "serializing - DllProcs" );
488
489 ar & boost::serialization::make_nvp("Hashmap_DllProc",
490 boost::serialization::base_object<Jenga::Common::Hashmap<DllProc>>(*this));
491 }
492
493public:
494 void Add(const NamespaceScopes &namespaceScopes, char *buffer,int nowLine);
495};
496
497void CollectProcedures( const BasicSource &source, UserProcs &userProcs, DllProcs &dllProcs );
498
499class ProcPointer : public Procedure
500{
501 // XMLシリアライズ用
502private:
503 friend class boost::serialization::access;
504 template<class Archive> void serialize(Archive& ar, const unsigned int version)
505 {
506 trace_for_serialize( "serializing - ProcPointer" );
507
508 ar & BOOST_SERIALIZATION_BASE_OBJECT_NVP( Procedure );
509 }
510
511public:
512 ProcPointer( Kind kind )
513 : Procedure( NamespaceScopes(), std::string(), kind, false )
514 {
515 }
516 ProcPointer()
517 {
518 }
519 ~ProcPointer(){}
520
521 virtual bool SetParamsAndReturnType( const char *sourceOfParams, int nowLine );
522};
523
524class ProcPointers : public vector<ProcPointer *>
525{
526 // XMLシリアライズ用
527private:
528 friend class boost::serialization::access;
529 template<class Archive> void serialize(Archive& ar, const unsigned int version)
530 {
531 trace_for_serialize( "serializing - ProcPointers" );
532
533 ar & boost::serialization::make_nvp("vector_ProcPointer",
534 boost::serialization::base_object<vector<ProcPointer *>>(*this));
535 }
536
537public:
538 ProcPointers()
539 {
540 }
541 ~ProcPointers()
542 {
543 Clear();
544 }
545
546 int Add( const string &typeExpression );
547 void Clear();
548 void PullOutAll()
549 {
550 clear();
551 }
552};
Note: See TracBrowser for help on using the repository browser.