source: dev/trunk/abdev/ProjectEditor/SubOperation.cpp@ 380

Last change on this file since 380 was 380, checked in by dai_9181, 16 years ago

Foreachに対応。
ジェネリクスインターフェイスに対応。

File size: 42.9 KB
Line 
1#include "Common.h"
2
3
4void ScreenToClient(HWND hwnd,RECT *pRect){
5 ScreenToClient(hwnd,(POINT *)pRect);
6 ScreenToClient(hwnd,(POINT *)(((long)(void *)pRect)+sizeof(POINT)));
7}
8void ClientToScreen(HWND hwnd,RECT *pRect){
9 ClientToScreen(hwnd,(POINT *)pRect);
10 ClientToScreen(hwnd,(POINT *)(((long)(void *)pRect)+sizeof(POINT)));
11}
12
13
14typedef BOOL (WINAPI *LPFN_ISWOW64PROCESS) (HANDLE hProcess,PBOOL Wow64Process);
15BOOL IsWow64(void){
16 ///////////////////////////////////////////////////////////
17 // ProjectEditor.exeがWOW64技術で動作しているのかどうか
18 ///////////////////////////////////////////////////////////
19 BOOL bIsWow64 = FALSE;
20 LPFN_ISWOW64PROCESS fnIsWow64Process = (LPFN_ISWOW64PROCESS)GetProcAddress(GetModuleHandle("kernel32"),"IsWow64Process");
21
22 if (NULL != fnIsWow64Process)
23 {
24 if (!fnIsWow64Process(GetCurrentProcess(),&bIsWow64))
25 {
26 // handle error
27 bIsWow64 = FALSE;
28 }
29 }
30 return bIsWow64;
31}
32
33void URLEncode(LPSTR pszSrc){
34 char *temp;
35 temp=(char *)malloc(65535);
36
37 int i,i2;
38 for (i = 0,i2=0; ; i++,i2++)
39 {
40 if(pszSrc[i]=='\0'){
41 temp[i2] = 0;
42 break;
43 }
44
45 // 英数字 _ . - は変換しないでそのまま
46 if (isalnum((BYTE)pszSrc[i]) || pszSrc[i] == '_' || pszSrc[i] == '.' || pszSrc[i] == '-'){
47 temp[i2] = pszSrc[i];
48 }
49 // それ以外は %3B のような形式に変換
50 else{
51 sprintf(temp+i2,"%%%02X", (BYTE)pszSrc[i]);
52 i2+=lstrlen(temp+i2);
53 i2--;
54 }
55 }
56
57 lstrcpy(pszSrc,temp);
58 free(temp);
59}
60
61void Digit(int num,char *buffer){
62 char temporary[255];
63 int i,iPos;
64
65 sprintf(temporary,"%d",abs(num));
66
67 //カンマが不要の場合は抜ける
68 if(lstrlen(temporary)<=3){
69 wsprintf(buffer,"%d",num);
70 return;
71 }
72
73 //合計の文字数からバッファを確保
74 if(num<0){
75 buffer[0]='-';
76 iPos=1;
77 }
78 else{
79 buffer[0]=0;
80 iPos=0;
81 }
82
83 //3桁毎にカンマを加えながら文字列をコピーする
84 int iFirst;
85 iFirst=lstrlen(temporary)%3;
86 if(iFirst==0) iFirst=3;
87 memcpy(buffer+iPos,temporary,iFirst);
88 iPos+=iFirst;
89
90 int i2;
91 i2=(lstrlen(temporary)-4)/3;
92
93 for(i=0;i<=i2;i++){
94 buffer[iPos]=',';
95 iPos++;
96 memcpy(buffer+iPos,temporary+i*3+iFirst,3);
97 iPos+=3;
98 buffer[iPos]=0;
99 }
100}
101
102void RectNaturalFormat(RECT *ReadRect,RECT *CopyRect){
103 if(ReadRect->left > ReadRect->right){
104 CopyRect->left=ReadRect->right;
105 CopyRect->right=ReadRect->left;
106 }
107 else{
108 CopyRect->left=ReadRect->left;
109 CopyRect->right=ReadRect->right;
110 }
111 if(ReadRect->top > ReadRect->bottom){
112 CopyRect->top=ReadRect->bottom;
113 CopyRect->bottom=ReadRect->top;
114 }
115 else{
116 CopyRect->top=ReadRect->top;
117 CopyRect->bottom=ReadRect->bottom;
118 }
119}
120void RectNaturalFormat(int *x1,int *y1,int *x2,int *y2){
121 int temp;
122 if(*x1>*x2){
123 temp=*x1;
124 *x1=*x2;
125 *x2=temp;
126 }
127 if(*y1>*y2){
128 temp=*y1;
129 *y1=*y2;
130 *y2=temp;
131 }
132}
133void KillSpaces(char *str1,char *str2){
134 int i,i2,IsStr;
135 for(i=0,i2=0,IsStr=0;;i++,i2++){
136 while((str1[i]==' '||str1[i]=='\t')&&IsStr==0&&str1[i]!='\0') i++;
137 if(str1[i]=='\"') IsStr^=1;
138 str2[i2]=str1[i];
139 if(str1[i]=='\0') break;
140 }
141}
142void RemoveStringQuotes(char *str){
143 int i;
144 if(str[0]!='\"') return;
145 for(i=0;;i++){
146 str[i]=str[i+1];
147 if(str[i]=='\"') break;
148 }
149 str[i]=0;
150}
151void SlideString(char *buffer, int slide){
152 char *temp;
153 temp=(char *)malloc(lstrlen(buffer)+1);
154 lstrcpy(temp,buffer);
155 lstrcpy(buffer+slide,temp);
156 free(temp);
157}
158void SlideBuffer(char *buffer,int length,int slide){
159 void *temp;
160 temp=malloc(length+1);
161 memcpy(temp,buffer,length);
162 memcpy(buffer+slide,temp,length);
163 free(temp);
164}
165BOOL IsVariableTopChar(char c){
166 if((c>='A'&&c<='Z')||(c>='a'&&c<='z')||c=='_') return 1;
167 return 0;
168}
169bool IsNumberChar( char c ){
170 if(c>='0'&&c<='9'){
171 return true;
172 }
173 return false;
174}
175BOOL IsVariableChar(char c){
176 if((c>='A'&&c<='Z')||(c>='a'&&c<='z')||(c>='0'&&c<='9')||
177 c=='_'||c=='.'||c=='$') return 1;
178 return 0;
179}
180
181BOOL IsCommandBackDelimitation(char *buffer,int pos){
182 if(buffer[pos]=='\n'||buffer[pos]==':') return 1;
183 return 0;
184}
185BOOL IsCommandDelimitation(char *buffer,int p){
186 if(buffer[p]=='\r'&&buffer[p+1]=='\n') return 2;
187 if(buffer[p]=='\n'||buffer[p]==':'||buffer[p]=='\0') return 1;
188 return 0;
189}
190
191char *ComparisonString( char *str1, char *str2, bool isBigSmall, bool isWordUnit ){
192 char *temp1 = (char *)malloc( lstrlen( str1 ) +1 );
193 char *temp2 = (char *)malloc( lstrlen( str2 ) +1 );
194
195 lstrcpy( temp1, str1 );
196 lstrcpy( temp2, str2 );
197
198 if( isBigSmall == false ){
199 // 大文字小文字を区別しない場合
200 // すべて大文字にしておく
201 CharUpper( temp1 );
202 CharUpper( temp2 );
203 }
204
205 int len2 = lstrlen( temp2 );
206
207 const char *temp3 = strstr( temp1, temp2 );
208 while( temp3 ){
209 if( isWordUnit ){
210 int pos = (int)temp3 - (int)temp1;
211 if( pos == 0 ){
212 if( !( IsVariableTopChar( temp1[len2] ) || IsNumberChar( temp1[len2] ) ) ){
213 break;
214 }
215 }
216 else{
217 if( !( IsVariableTopChar( temp1[pos-1] ) || IsNumberChar( temp1[pos-1] ) )
218 && !( IsVariableTopChar( temp1[pos+len2] ) || IsNumberChar( temp1[pos+len2] ) )
219 ){
220 break;
221 }
222 }
223 }
224 else{
225 break;
226 }
227
228 temp3 = strstr( temp3 + 1, temp2 );
229 }
230
231 char *result = NULL;
232 if( temp3 ){
233 int pos = (int)temp3 - (int)temp1;
234 result = str1 + pos;
235 }
236
237 free( temp1 );
238 free( temp2 );
239
240 return result;
241}
242int GetOneParameter(char *Parameter,int pos,char *retAns){
243 int i,i2,IsStr,PareNum;
244 for(i=pos,i2=0,IsStr=0,PareNum=0;;i++,i2++){
245 if(IsDBCSLeadByte(Parameter[i])){
246 retAns[i2]=Parameter[i];
247 retAns[++i2]=Parameter[++i];
248 continue;
249 }
250 if(Parameter[i]=='\"') IsStr^=1;
251 if(Parameter[i]=='('&&IsStr==0) PareNum++;
252 if(Parameter[i]==')'&&IsStr==0) PareNum--;
253 if(Parameter[i]==','&&IsStr==0&&PareNum==0){
254 retAns[i2]=0;
255 break;
256 }
257 retAns[i2]=Parameter[i];
258 if(Parameter[i]=='\0'||Parameter[i]=='\r'&&Parameter[i+1]=='\n'){
259 retAns[i2]=0;
260 break;
261 }
262 }
263 if(Parameter[i]==',') i++;
264 return i;
265}
266int GetStringInPare(char *buffer,char *ReadBuffer){
267 int i,IsStr,PareNum;
268 for(i=0,IsStr=0,PareNum=0;;i++){
269 buffer[i]=ReadBuffer[i];
270 if(ReadBuffer[i]=='\"') IsStr^=1;
271 else if(ReadBuffer[i]=='('&&IsStr==0) PareNum++;
272 else if(ReadBuffer[i]==')'&&IsStr==0){
273 PareNum--;
274 if(PareNum==0){
275 i++;
276 buffer[i]=0;
277 break;
278 }
279 }
280 else if(ReadBuffer[i]=='\0') return 0;
281 }
282 return i;
283}
284int GetStringInBracket(char *buffer,char *ReadBuffer){
285 int i,IsStr,PareNum;
286 for(i=0,IsStr=0,PareNum=0;;i++){
287 buffer[i]=ReadBuffer[i];
288 if(IsDBCSLeadByte(ReadBuffer[i])){
289 i++;
290 buffer[i]=ReadBuffer[i];
291 continue;
292 }
293 if(ReadBuffer[i]=='\"') IsStr^=1;
294 else if(ReadBuffer[i]=='['&&IsStr==0) PareNum++;
295 else if(ReadBuffer[i]==']'&&IsStr==0){
296 PareNum--;
297 if(PareNum==0){
298 i++;
299 buffer[i]=0;
300 break;
301 }
302 }
303 else if(ReadBuffer[i]=='\0') return 0;
304 }
305 return i;
306}
307void JumpBlank(char *pBuf,int *piPos){
308 int i;
309 i=*piPos;
310
311 while(1){
312 while(pBuf[i]==' '||pBuf[i]=='\t') i++;
313 if(pBuf[i]=='\0') break;
314 if(pBuf[i]=='\''){
315 //注釈文(一行)
316 for(i++;;i++){
317 if(pBuf[i]=='\0') break;
318 if(pBuf[i]=='\r'&&pBuf[i+1]=='\n'){
319 i+=2;
320 break;
321 }
322 }
323 while(pBuf[i]==' '||pBuf[i]=='\t') i++;
324 }
325 if(pBuf[i]=='/'&&pBuf[i+1]=='*'){
326 //注釈文(複数行)
327 i+=2;
328 while(!(pBuf[i]=='*'&&pBuf[i+1]=='/')){
329 i++;
330 if(pBuf[i]=='\0') break;
331 }
332 if(pBuf[i]){
333 i+=2;
334 }
335 }
336 while(pBuf[i]=='\r'&&pBuf[i+1]=='\n') i+=2;
337
338 if(!(
339 pBuf[i]==' '||
340 pBuf[i]=='\t'||
341 pBuf[i]=='\''||
342 (pBuf[i]=='/'&&pBuf[i+1]=='*')
343 )) break;
344 }
345
346 *piPos=i;
347}
348
349BOOL CheckParenthesis(char *buffer){
350 int i,IsStr,PareNum,sw;
351 _int8 bracket[1024];
352
353 for(i=0,IsStr=0,PareNum=0,sw=0;;i++){
354 if(buffer[i]=='\"'){
355 IsStr^=1;
356 continue;
357 }
358
359 else if(buffer[i]=='('&&IsStr==0){
360 bracket[PareNum]=0;
361 PareNum++;
362 }
363 else if(buffer[i]=='['&&IsStr==0){
364 bracket[PareNum]=1;
365 PareNum++;
366 }
367
368 else if(buffer[i]==')'&&IsStr==0){
369 PareNum--;
370 if(bracket[PareNum]!=0||PareNum<0){
371 //"カッコ \'( )\'"
372 return 0;
373 }
374 }
375 else if(buffer[i]==']'&&IsStr==0){
376 PareNum--;
377 if(bracket[PareNum]!=1||PareNum<0){
378 //"カッコ \'( )\'"
379 return 0;
380 }
381 }
382
383 else if(buffer[i]=='\n'||buffer[i]=='\0'){
384
385 //"カッコ \'( )\'"
386 if(buffer[i]=='\0'){
387 if(PareNum!=0){
388 return 0;
389 }
390
391 if(IsStr!=0){
392 return 0;
393 }
394 }
395 if(buffer[i]=='\0') break;
396
397 sw=0;
398 }
399 }
400 return 1;
401}
402
403DWORD GetValue(char *value){
404 unsigned long ans;
405 if(value[0]=='&'){
406 if(value[1]=='o'||value[1]=='O') sscanf(value+2,"%o",&ans);
407 if(value[1]=='h'||value[1]=='H') sscanf(value+2,"%x",&ans);
408 }
409 else ans=atol(value);
410 return ans;
411}
412BOOL IsManagementCommand(int ComNum){
413 switch(ComNum){
414 case -1:
415 case COM_ABSTRACT:
416 case COM_CLASS:
417 case COM_CONST:
418 case COM_DEBUG:
419 case COM_DECLARE:
420 case COM_DEF:
421 case COM_DIM:
422 case COM_DO:
423 case COM_END:
424 case COM_ENUM:
425 case COM_FOR:
426 case COM_FUNCTION:
427 case COM_GOSUB:
428 case COM_GOTO:
429 case COM_IF:
430 case COM_INHERITS:
431 case COM_INTERFACE:
432 case COM_LOOP:
433 case COM_NAMESPACE:
434 case COM_NEXT:
435 case COM_PRIVATE:
436 case COM_PROTECTED:
437 case COM_PUBLIC:
438 case COM_RETURN:
439 case COM_SELECT:
440 case COM_SUB:
441 case COM_TRY:
442 case COM_TYPE:
443 case COM_TYPEDEF:
444 case COM_VIRTUAL:
445 case COM_OVERRIDE:
446 case COM_WEND:
447 case COM_WHILE:
448 case COM_WITH:
449 return 1;
450 default:
451 break;
452 }
453 return 0;
454}
455int IsBasicReservedWord(char *str){
456 if(str[0]=='a'||str[0]=='A'){
457 if(lstrcmpi(str,"Abstract")==0) return COM_ABSTRACT;
458 if(lstrcmpi(str,"As")==0) return -1;
459 }
460 else if(str[0]=='b'||str[0]=='B'){
461 if(lstrcmpi(str,"Beep")==0) return COM_BEEP;
462 if(lstrcmp(str,"Boolean")==0) return -1;
463 if(lstrcmpi(str,"ByRef")==0) return -1;
464 if(lstrcmpi(str,"ByVal")==0) return -1;
465 if(lstrcmp(str,"Byte")==0) return -1;
466 }
467 else if(str[0]=='c'||str[0]=='C'){
468 if(lstrcmpi(str,"Catch")==0) return -1;
469 if(lstrcmpi(str,"Case")==0) return -1;
470 if(lstrcmp(str,"Char")==0) return -1;
471 if(lstrcmpi(str,"ChDir")==0) return COM_CHDIR;
472 if(lstrcmpi(str,"Circle")==0) return COM_CIRCLE;
473 if(lstrcmpi(str,"Class")==0) return COM_CLASS;
474 if(lstrcmpi(str,"Close")==0) return COM_CLOSE;
475 if(lstrcmpi(str,"Cls")==0) return COM_CLS;
476 if(lstrcmpi(str,"Color")==0) return COM_COLOR;
477 if(lstrcmpi(str,"Const")==0) return COM_CONST;
478 if(lstrcmpi(str,"Continue")==0) return -1;
479 }
480 else if(str[0]=='d'||str[0]=='D'){
481 if(lstrcmpi(str,"Debug")==0) return COM_DEBUG;
482 if(lstrcmpi(str,"Declare")==0) return COM_DECLARE;
483 if(lstrcmpi(str,"Def")==0) return COM_DEF;
484 if(lstrcmpi(str,"Delete")==0) return -1;
485 if(lstrcmpi(str,"DelWnd")==0) return COM_DELWND;
486 if(lstrcmpi(str,"Dim")==0) return COM_DIM;
487 if(lstrcmpi(str,"Do")==0) return COM_DO;
488 if(lstrcmp(str,"Double")==0) return -1;
489 if(lstrcmp(str,"DWord")==0) return -1;
490 }
491 else if(str[0]=='e'||str[0]=='E'){
492 if(lstrcmpi(str,"Else")==0) return -1;
493 if(lstrcmpi(str,"ElseIf")==0) return -1;
494 if(lstrcmpi(str,"End")==0) return COM_END;
495 if(lstrcmpi(str,"EndIf")==0) return -1;
496 if(lstrcmpi(str,"EndFunction")==0) return -1;
497 if(lstrcmpi(str,"EndSub")==0) return -1;
498 if(lstrcmpi(str,"EndType")==0) return -1;
499 if(lstrcmpi(str,"EndSelect")==0) return -1;
500 if(lstrcmpi(str,"EndWith")==0) return -1;
501 if(lstrcmpi(str,"Enum")==0) return COM_ENUM;
502 if(lstrcmpi(str,"Exit")==0) return -1;
503 if(lstrcmpi(str,"ExitDo")==0) return -1;
504 if(lstrcmpi(str,"ExitFor")==0) return -1;
505 if(lstrcmpi(str,"ExitFunction")==0) return -1;
506 if(lstrcmpi(str,"ExitSub")==0) return -1;
507 if(lstrcmpi(str,"ExitWhile")==0) return -1;
508 }
509 else if(str[0]=='f'||str[0]=='F'){
510 if(lstrcmp(str,"False")==0) return -1;
511 if(lstrcmpi(str,"Field")==0) return COM_FIELD;
512 if(lstrcmpi(str,"Finally")==0) return -1;
513 if(lstrcmpi(str,"For")==0) return COM_FOR;
514 if(lstrcmpi(str,"Foreach")==0) return -1;
515 if(lstrcmpi(str,"Function")==0) return COM_FUNCTION;
516 }
517 else if(str[0]=='g'||str[0]=='G'){
518 if(lstrcmpi(str,"Get")==0) return COM_GET;
519 if(lstrcmpi(str,"GoSub")==0) return COM_GOSUB;
520 if(lstrcmpi(str,"Goto")==0) return COM_GOTO;
521 }
522 else if(str[0]=='i'||str[0]=='I'){
523 if(lstrcmpi(str,"If")==0) return COM_IF;
524 if(lstrcmpi(str,"Imports")==0) return -1;
525 if(lstrcmpi(str,"Implements")==0) return -1;
526 if(lstrcmpi(str,"Inherits")==0) return COM_INHERITS;
527 if(lstrcmpi(str,"Input")==0) return COM_INPUT;
528 if(lstrcmp(str,"Int64")==0) return -1;
529 if(lstrcmp(str,"Integer")==0) return -1;
530 if(lstrcmpi(str,"Interface")==0) return COM_INTERFACE;
531 }
532 else if(str[0]=='k'||str[0]=='K'){
533 if(lstrcmpi(str,"Kill")==0) return COM_KILL;
534 }
535 else if(str[0]=='l'||str[0]=='L'){
536 if(lstrcmpi(str,"Let")==0) return COM_LET;
537 if(lstrcmpi(str,"Line")==0) return COM_LINE;
538 if(lstrcmpi(str,"Locate")==0) return COM_LOCATE;
539 if(lstrcmp(str,"Long")==0) return -1;
540 if(lstrcmpi(str,"Loop")==0) return COM_LOOP;
541 }
542 else if(str[0]=='m'||str[0]=='M'){
543 if(lstrcmpi(str,"MkDir")==0) return COM_MKDIR;
544 if(lstrcmpi(str,"MsgBox")==0) return COM_MSGBOX;
545 }
546 else if(str[0]=='n'||str[0]=='N'){
547 if(lstrcmpi(str,"Namespace")==0) return COM_NAMESPACE;
548 if(lstrcmpi(str,"Next")==0) return COM_NEXT;
549 if(lstrcmpi(str,"New")==0) return -1;
550 if(lstrcmpi(str,"Nothing")==0) return -1;
551 }
552 else if(str[0]=='o'||str[0]=='O'){
553 if(lstrcmp(str,"Object")==0) return -1;
554 if(lstrcmpi(str,"Open")==0) return COM_OPEN;
555 if(lstrcmpi(str,"Operator")==0) return -1;
556 if(lstrcmpi(str,"Override")==0) return COM_OVERRIDE;
557 }
558 else if(str[0]=='p'||str[0]=='P'){
559 if(lstrcmpi(str,"Paint")==0) return COM_PAINT;
560 if(lstrcmpi(str,"Print")==0) return COM_PRINT;
561 if(lstrcmpi(str,"Private")==0) return COM_PRIVATE;
562 if(lstrcmpi(str,"Protected")==0) return COM_PROTECTED;
563 if(lstrcmpi(str,"PSet")==0) return COM_PSET;
564 if(lstrcmpi(str,"Put")==0) return COM_PUT;
565 if(lstrcmpi(str,"Public")==0) return COM_PUBLIC;
566 }
567 else if(str[0]=='q'||str[0]=='Q'){
568 if(lstrcmp(str,"QWord")==0) return -1;
569 }
570 else if(str[0]=='r'||str[0]=='R'){
571 if(lstrcmpi(str,"Randomize")==0) return COM_RANDOMIZE;
572 if(lstrcmpi(str,"Rem")==0) return COM_REM;
573 if(lstrcmpi(str,"Return")==0) return COM_RETURN;
574 }
575 else if(str[0]=='s'||str[0]=='S'){
576 if(lstrcmp(str,"SByte")==0) return -1;
577 if(lstrcmpi(str,"Select")==0) return COM_SELECT;
578 if(lstrcmpi(str,"SelectCase")==0) return COM_SELECT;
579 if(lstrcmp(str,"Single")==0) return -1;
580 if(lstrcmpi(str,"Sleep")==0) return COM_SLEEP;
581 if(lstrcmp(str,"Static")==0) return -1;
582 if(lstrcmp(str,"String")==0) return -1;
583 if(lstrcmpi(str,"Sub")==0) return COM_SUB;
584 if(lstrcmpi(str,"Super")==0) return -1;
585 }
586 else if(str[0]=='t'||str[0]=='T'){
587 if(lstrcmpi(str,"Then")==0) return -1;
588 if(lstrcmpi(str,"This")==0) return -1;
589 if(lstrcmpi(str,"Throw")==0) return -1;
590 if(lstrcmp(str,"True")==0) return -1;
591 if(lstrcmp(str,"Try")==0) return COM_TRY;
592 if(lstrcmpi(str,"Type")==0) return COM_TYPE;
593 if(lstrcmpi(str,"TypeDef")==0) return COM_TYPEDEF;
594 }
595 else if(str[0]=='u'||str[0]=='U'){
596 if(lstrcmpi(str,"Until")==0) return -1;
597 }
598 else if(str[0]=='v'||str[0]=='V'){
599 if(lstrcmpi(str,"Virtual")==0) return COM_VIRTUAL;
600 }
601 else if(str[0]=='w'||str[0]=='W'){
602 if(lstrcmpi(str,"Wend")==0) return COM_WEND;
603 if(lstrcmpi(str,"While")==0) return COM_WHILE;
604 if(lstrcmpi(str,"Window")==0) return COM_WINDOW;
605 if(lstrcmpi(str,"With")==0) return COM_WITH;
606 if(lstrcmp(str,"Word")==0) return -1;
607 if(lstrcmpi(str,"Write")==0) return COM_WRITE;
608 }
609 else if(str[0]=='#'){
610 if(lstrcmpi(str,"#include")==0) return -1;
611 if(lstrcmpi(str,"#strict")==0) return -1;
612 if(lstrcmpi(str,"#console")==0) return -1;
613 if(lstrcmpi(str,"#prompt")==0) return -1;
614 if(lstrcmpi(str,"#N88BASIC")==0) return -1;
615 if(lstrcmpi(str,"#define")==0) return -1;
616 if(lstrcmpi(str,"#ifdef")==0) return -1;
617 if(lstrcmpi(str,"#ifndef")==0) return -1;
618 if(lstrcmpi(str,"#else")==0) return -1;
619 if(lstrcmpi(str,"#endif")==0) return -1;
620 }
621 return 0;
622}
623
624HBITMAP CreateGradationBitmap(SIZE *pSize,COLORREF color1,COLORREF color2){
625 //グラデーションビットマップを生成
626
627 BITMAPINFO BitmapInfo;
628 memset(&BitmapInfo.bmiHeader,0,sizeof(BITMAPINFOHEADER));
629 BitmapInfo.bmiHeader.biSize=sizeof(BITMAPINFOHEADER);
630 BitmapInfo.bmiHeader.biWidth=pSize->cx;
631 BitmapInfo.bmiHeader.biHeight=pSize->cy;
632 BitmapInfo.bmiHeader.biPlanes=1;
633 BitmapInfo.bmiHeader.biBitCount=24;
634
635 HDC hdc;
636 hdc=GetDC(GetDesktopWindow());
637
638 HBITMAP hBitmap;
639 BYTE *pByte;
640 hBitmap=CreateDIBSection(hdc,&BitmapInfo,DIB_RGB_COLORS,(void **)&pByte,0,0);
641
642 int i,i2,x,y;
643 COLORREF rgb;
644 i=BitmapInfo.bmiHeader.biWidth*3;
645 if(i%sizeof(LONG)!=0) i+=sizeof(LONG)-(i%sizeof(LONG));
646 for(y=0;y<BitmapInfo.bmiHeader.biHeight;y++){
647 if(y<BitmapInfo.bmiHeader.biHeight/2-2) rgb=color2;
648 else if(y>BitmapInfo.bmiHeader.biHeight/2+2) rgb=color1;
649 else{
650 double ratio;
651 ratio=((double)y-((double)BitmapInfo.bmiHeader.biHeight/(double)2-(double)2))/(double)4;
652 //ratio=(double)y/(double)BitmapInfo.bmiHeader.biHeight;
653 rgb=RGB(
654 LOBYTE(LOWORD(color2))+(int)(double)(LOBYTE(LOWORD(color1))-LOBYTE(LOWORD(color2)))*(ratio), //赤要素
655 HIBYTE(LOWORD(color2))+(int)(double)(HIBYTE(LOWORD(color1))-HIBYTE(LOWORD(color2)))*(ratio), //緑要素
656 LOBYTE(HIWORD(color2))+(int)(double)(LOBYTE(HIWORD(color1))-LOBYTE(HIWORD(color2)))*(ratio) //青要素
657 );
658 }
659 for(x=0;x<BitmapInfo.bmiHeader.biWidth;x++){
660 i2=y*i+x*3;
661 pByte[i2+2]=LOBYTE(LOWORD(rgb));
662 pByte[i2+1]=HIBYTE(LOWORD(rgb));
663 pByte[i2]=LOBYTE(HIWORD(rgb));
664 }
665 }
666
667 ReleaseDC(GetDesktopWindow(),hdc);
668
669 return hBitmap;
670}
671HBITMAP CreateVertGradationBitmap(SIZE *pSize,COLORREF color1,COLORREF color2){
672 //グラデーションビットマップを生成
673
674 BITMAPINFO BitmapInfo;
675 memset(&BitmapInfo.bmiHeader,0,sizeof(BITMAPINFOHEADER));
676 BitmapInfo.bmiHeader.biSize=sizeof(BITMAPINFOHEADER);
677 BitmapInfo.bmiHeader.biWidth=pSize->cx;
678 BitmapInfo.bmiHeader.biHeight=pSize->cy;
679 BitmapInfo.bmiHeader.biPlanes=1;
680 BitmapInfo.bmiHeader.biBitCount=24;
681
682 HDC hdc;
683 hdc=GetDC(GetDesktopWindow());
684
685 HBITMAP hBitmap;
686 BYTE *pByte;
687 hBitmap=CreateDIBSection(hdc,&BitmapInfo,DIB_RGB_COLORS,(void **)&pByte,0,0);
688
689 int i,i2,x,y;
690 COLORREF rgb;
691 i=BitmapInfo.bmiHeader.biWidth*3;
692 if(i%sizeof(LONG)!=0) i+=sizeof(LONG)-(i%sizeof(LONG));
693 for(y=0;y<BitmapInfo.bmiHeader.biHeight;y++){
694 if(y<BitmapInfo.bmiHeader.biHeight/2-2) rgb=color2;
695 else if(y>BitmapInfo.bmiHeader.biHeight/2+2) rgb=color1;
696 else{
697 double ratio;
698 ratio=(double)y/(double)BitmapInfo.bmiHeader.biHeight;
699 rgb=RGB(
700 LOBYTE(LOWORD(color2))+(int)(double)(LOBYTE(LOWORD(color1))-LOBYTE(LOWORD(color2)))*(ratio), //赤要素
701 HIBYTE(LOWORD(color2))+(int)(double)(HIBYTE(LOWORD(color1))-HIBYTE(LOWORD(color2)))*(ratio), //緑要素
702 LOBYTE(HIWORD(color2))+(int)(double)(LOBYTE(HIWORD(color1))-LOBYTE(HIWORD(color2)))*(ratio) //青要素
703 );
704 }
705 for(x=0;x<BitmapInfo.bmiHeader.biWidth;x++){
706 i2=y*i+x*3;
707 pByte[i2+2]=LOBYTE(LOWORD(rgb));
708 pByte[i2+1]=HIBYTE(LOWORD(rgb));
709 pByte[i2]=LOBYTE(HIWORD(rgb));
710 }
711 }
712
713 ReleaseDC(GetDesktopWindow(),hdc);
714
715 return hBitmap;
716}
717HBITMAP CreateHorzGradationBitmap(SIZE *pSize,COLORREF color1,COLORREF color2){
718 //グラデーションビットマップを生成
719
720 BITMAPINFO BitmapInfo;
721 memset(&BitmapInfo.bmiHeader,0,sizeof(BITMAPINFOHEADER));
722 BitmapInfo.bmiHeader.biSize=sizeof(BITMAPINFOHEADER);
723 BitmapInfo.bmiHeader.biWidth=pSize->cx;
724 BitmapInfo.bmiHeader.biHeight=pSize->cy;
725 BitmapInfo.bmiHeader.biPlanes=1;
726 BitmapInfo.bmiHeader.biBitCount=24;
727
728 HDC hdc;
729 hdc=GetDC(GetDesktopWindow());
730
731 HBITMAP hBitmap;
732 BYTE *pByte;
733 hBitmap=CreateDIBSection(hdc,&BitmapInfo,DIB_RGB_COLORS,(void **)&pByte,0,0);
734
735 int i,i2,x,y;
736 COLORREF rgb;
737 i=BitmapInfo.bmiHeader.biWidth*3;
738 if(i%sizeof(LONG)!=0) i+=sizeof(LONG)-(i%sizeof(LONG));
739 for(x=0;x<BitmapInfo.bmiHeader.biWidth;x++){
740 double ratio;
741 ratio=(double)x/(double)BitmapInfo.bmiHeader.biWidth;
742 rgb=RGB(
743 LOBYTE(LOWORD(color1))+(int)(double)(LOBYTE(LOWORD(color2))-LOBYTE(LOWORD(color1)))*(ratio), //赤要素
744 HIBYTE(LOWORD(color1))+(int)(double)(HIBYTE(LOWORD(color2))-HIBYTE(LOWORD(color1)))*(ratio), //緑要素
745 LOBYTE(HIWORD(color1))+(int)(double)(LOBYTE(HIWORD(color2))-LOBYTE(HIWORD(color1)))*(ratio) //青要素
746 );
747 for(y=0;y<BitmapInfo.bmiHeader.biHeight;y++){
748 i2=y*i+x*3;
749 pByte[i2+2]=LOBYTE(LOWORD(rgb));
750 pByte[i2+1]=HIBYTE(LOWORD(rgb));
751 pByte[i2]=LOBYTE(HIWORD(rgb));
752 }
753 }
754
755 ReleaseDC(GetDesktopWindow(),hdc);
756
757 return hBitmap;
758}
759HICON CreateGrayIcon(HICON hBaseIcon){
760 ////////////////////////
761 // 淡色アイコンを生成
762 ////////////////////////
763
764 HICON hGrayIcon;
765
766 ICONINFO IconInfo;
767 GetIconInfo(hBaseIcon,&IconInfo);
768
769
770 //ビットマップを加工
771 BITMAP Bitmap;
772 GetObject(IconInfo.hbmColor,sizeof(Bitmap),&Bitmap);
773
774 BITMAPINFO BitmapInfo;
775 memset(&BitmapInfo.bmiHeader,0,sizeof(BITMAPINFOHEADER));
776 BitmapInfo.bmiHeader.biSize=sizeof(BITMAPINFOHEADER);
777 BitmapInfo.bmiHeader.biWidth=Bitmap.bmWidth;
778 BitmapInfo.bmiHeader.biHeight=Bitmap.bmHeight;
779 BitmapInfo.bmiHeader.biPlanes=1;
780 BitmapInfo.bmiHeader.biBitCount=24;
781 BitmapInfo.bmiHeader.biCompression=BI_RGB;
782
783 HDC hdc;
784 hdc=GetDC(GetDesktopWindow());
785
786 BYTE *pByte;
787 pByte=(BYTE *)HeapAlloc(hHeap,0,Bitmap.bmWidth*Bitmap.bmHeight*sizeof(COLORREF));
788 GetDIBits(hdc,
789 IconInfo.hbmColor,
790 0,
791 Bitmap.bmHeight,
792 (void *)pByte,
793 &BitmapInfo,
794 DIB_RGB_COLORS);
795
796 int i,i2,x,y;
797 i=BitmapInfo.bmiHeader.biWidth*3;
798 if(i%sizeof(LONG)!=0) i+=sizeof(LONG)-(i%sizeof(LONG));
799 for(x=0;x<BitmapInfo.bmiHeader.biWidth;x++){
800 for(y=0;y<BitmapInfo.bmiHeader.biHeight;y++){
801 i2=y*i+x*3;
802 if(pByte[i2+2]==0&&pByte[i2+1]==0&&pByte[i2]==0){
803 //透明色
804 //何もしない
805 }
806 else{
807 double ratio=0.5; //明るさ
808
809 pByte[i2+2]+=(BYTE)((double)(255-pByte[i2+2])*ratio);
810 pByte[i2+1]+=(BYTE)((double)(255-pByte[i2+1])*ratio);
811 pByte[i2]+=(BYTE)((double)(255-pByte[i2])*ratio);
812
813 pByte[i2+2]=(BYTE)(((int)pByte[i2+2]+(int)pByte[i2+1]+(int)pByte[i2])/3);
814 pByte[i2+1]=pByte[i2+2];
815 pByte[i2]=pByte[i2+2];
816 }
817 }
818 }
819
820 SetDIBits(hdc,
821 IconInfo.hbmColor,
822 0,
823 Bitmap.bmHeight,
824 (void *)pByte,
825 &BitmapInfo,
826 DIB_RGB_COLORS);
827
828 HeapDefaultFree(pByte);
829
830 ReleaseDC(GetDesktopWindow(),hdc);
831
832
833 hGrayIcon=CreateIconIndirect(&IconInfo);
834
835 //不要なビットマップを破棄
836 DeleteObject(IconInfo.hbmMask);
837 DeleteObject(IconInfo.hbmColor);
838
839 return hGrayIcon;
840}
841void GetSize(SIZE *pSize,RECT *pRect){
842 pSize->cx=pRect->right-pRect->left;
843 pSize->cy=pRect->bottom-pRect->top;
844}
845BOOL HitTest(RECT *pRect,POINT *pPos){
846 if(pRect->left<=pPos->x&&pPos->x<pRect->right&&
847 pRect->top<=pPos->y&&pPos->y<pRect->bottom) return 1;
848 return 0;
849}
850BOOL Rectangle(HDC hdc,RECT *pRect){
851 return Rectangle(hdc,pRect->left,pRect->top,pRect->right,pRect->bottom);
852}
853
854void ComboBox_SetSelText(HWND hCombo,char *lpszText){
855 SendMessage(hCombo,CB_SETCURSEL,
856 SendMessage(hCombo,CB_FINDSTRINGEXACT,0,(LPARAM)lpszText),
857 0);
858}
859
860void SetCursorByState(int state){
861 if(state==FRAME_UPPER_LEFT||state==FRAME_LOWER_RIGHT) SetCursor(LoadCursor(0,IDC_SIZENWSE));
862 else if(state==FRAME_UPPER_RIGHT||state==FRAME_LOWER_LEFT) SetCursor(LoadCursor(0,IDC_SIZENESW));
863 else if(state==FRAME_LEFT||state==FRAME_RIGHT) SetCursor(LoadCursor(0,IDC_SIZEWE));
864 else if(state==FRAME_UPPER||state==FRAME_LOWER) SetCursor(LoadCursor(0,IDC_SIZENS));
865 else if(state==FRAME_INSIDE) SetCursor(LoadCursor(0,IDC_SIZEALL));
866 else SetCursor(LoadCursor(0,IDC_ARROW));
867}
868
869void SetTextEditColorDesign(TEXTEDIT_COLOR_INFO *pColorInfo,CTheme *pobj_Theme,BOOL bRedraw){
870 pColorInfo->rgbDefault=pobj_Theme->TextColorInfo.rgbDefault;
871 pColorInfo->rgbComment=pobj_Theme->TextColorInfo.rgbComment;
872 pColorInfo->rgbStatement=pobj_Theme->TextColorInfo.rgbStatement;
873 pColorInfo->rgbString=pobj_Theme->TextColorInfo.rgbString;
874 pColorInfo->rgbCursorBack=pobj_Theme->TextColorInfo.rgbCursorBack;
875 pColorInfo->rgbBackground=pobj_Theme->TextColorInfo.rgbBackground;
876
877 //アクティブテーマにセット
878 lstrcpy(pobj_nv->szActiveTheme,pobj_Theme->m_name);
879
880 //テーマ依存の描画リソースを取得
881 pobj_DBTheme->unlock();
882 pobj_DBTheme->lock();
883
884 if(bRedraw){
885 //再描画
886 extern MDIINFO MdiInfo[MAX_WNDNUM];
887 int i;
888 for(i=0;i<MAX_WNDNUM;i++){
889 if(MdiInfo[i].hwnd){
890 if(IS_DOCUMENT_TEXT(MdiInfo[i].DocType)){
891 SetTextEditWordColor(i);
892 InvalidateRect(MdiInfo[i].pMdiTextEdit->hEdit,NULL,0);
893 }
894 }
895 }
896 }
897}
898
899BOOL SetupProjectEditor(void){
900 extern HINSTANCE hInst;
901 int i;
902 char str[MAX_PATH],temporary[MAX_PATH];
903
904
905 //リソース用DLLをマッピング
906#if defined(JPN)
907 //日本語リソース
908 sprintf(temporary,"%sSubOperation\\res.dll",pj_editor_Dir);
909#else
910 //英語リソース
911 sprintf(temporary,"%sSubOperation\\res_e.dll",pj_editor_Dir);
912#endif
913 hResInst=LoadLibrary(temporary);
914
915 //アイコンリソースDLLをマッピング
916 sprintf(temporary,"%sSubOperation\\icon_res.dll",pj_editor_Dir);
917 hIconResInst=LoadLibrary(temporary);
918
919 //LuxCtrl.dllをマッピング
920 sprintf(temporary,"%sSubOperation\\LuxCtrl.dll",pj_editor_Dir);
921 hLib_LuxCtrl=LoadLibrary(temporary);
922 if(!hLib_LuxCtrl){
923 MessageBox(0,"LuxCtrl.dllの読み込みに失敗しました。",APPLICATION_NAME,MB_OK|MB_ICONEXCLAMATION);
924 return 0;
925 }
926 LuxToolbar_CreateInstance=
927 (PROC_LuxToolbar_CreateInstance)GetProcAddress(hLib_LuxCtrl,"LuxToolbar_CreateInstance");
928
929
930 //モジュールディレクトリを取得
931 GetModuleFileName(hInst,temporary,MAX_PATH);
932 _splitpath(temporary,pj_editor_Dir,str,NULL,NULL);
933 lstrcat(pj_editor_Dir,str);
934
935 //ヒープオブジェクトを作成
936 extern HANDLE hHeap;
937 hHeap=HeapCreate(HEAP_GENERATE_EXCEPTIONS,0,0);
938
939
940 //自動バックアップ用のディレクトリを生成
941 CreateBackupDir();
942
943
944 //COMを初期化
945 CoInitialize(0);
946
947 //スクリーンサイズを取得
948 ScreenX=GetSystemMetrics(SM_CXSCREEN);
949 ScreenY=GetSystemMetrics(SM_CYSCREEN);
950
951 //コンパイラ名をセット(デフォルトはWin32)
952 extern char *lpszCompilerName;
953 lpszCompilerName=WIN32_COMPILER_NAME;
954
955 //不揮発性のデータを取得
956 pobj_nv=new CNonVolatile;
957 pobj_nv->load();
958
959
960 //アルファブレンド用のAPIを取得
961 extern FWINLAYER pSetLayeredWindowAttributes;
962 extern HINSTANCE hUser32Lib;
963 hUser32Lib=LoadLibrary("user32.dll");
964 pSetLayeredWindowAttributes=(FWINLAYER)GetProcAddress(hUser32Lib,"pSetLayeredWindowAttributes");
965
966
967
968
969 /////////////////////
970 // フォントを定義
971 /////////////////////
972
973 //パラメータ ヒント フォント
974 extern METHODCHECKINFO MethodCheckInfo;
975 MethodCheckInfo.hFont=CreateFontIndirect(&MethodCheckInfo.LogFont);
976 i=MethodCheckInfo.LogFont.lfWeight;
977 MethodCheckInfo.LogFont.lfWeight=FW_BOLD;
978 MethodCheckInfo.hBoldFont=CreateFontIndirect(&MethodCheckInfo.LogFont);
979 MethodCheckInfo.LogFont.lfWeight=i;
980
981 //ステータスバー フォント
982 LOGFONT LogFont;
983 extern HFONT hStatusFont;
984 LogFont.lfHeight=-12;
985 LogFont.lfWidth=0;
986 LogFont.lfEscapement=0;
987 LogFont.lfOrientation=0;
988 LogFont.lfWeight=FW_REGULAR;
989 LogFont.lfItalic=NULL;
990 LogFont.lfUnderline=NULL;
991 LogFont.lfStrikeOut=NULL;
992 LogFont.lfCharSet=SHIFTJIS_CHARSET;
993 LogFont.lfOutPrecision=OUT_STRING_PRECIS;
994 LogFont.lfClipPrecision=CLIP_STROKE_PRECIS;
995 LogFont.lfQuality=DRAFT_QUALITY;
996 LogFont.lfPitchAndFamily=VARIABLE_PITCH;
997 sprintf(LogFont.lfFaceName,"MS Pゴシック");
998 hStatusFont=CreateFontIndirect(&LogFont);
999
1000 //ハイパーリンク フォント
1001 extern HFONT hHyperLinkFont;
1002 LogFont.lfHeight=-12;
1003 LogFont.lfWidth=0;
1004 LogFont.lfEscapement=0;
1005 LogFont.lfOrientation=0;
1006 LogFont.lfWeight=FW_REGULAR;
1007 LogFont.lfItalic=NULL;
1008 LogFont.lfUnderline=TRUE;
1009 LogFont.lfStrikeOut=NULL;
1010 LogFont.lfCharSet=SHIFTJIS_CHARSET;
1011 LogFont.lfOutPrecision=OUT_STRING_PRECIS;
1012 LogFont.lfClipPrecision=CLIP_STROKE_PRECIS;
1013 LogFont.lfQuality=DRAFT_QUALITY;
1014 LogFont.lfPitchAndFamily=VARIABLE_PITCH;
1015 sprintf(LogFont.lfFaceName,"MS Pゴシック");
1016 hHyperLinkFont=CreateFontIndirect(&LogFont);
1017
1018 //ルーラー フォント
1019 extern HFONT hRulerFont;
1020 LogFont.lfHeight=-10;
1021 LogFont.lfWidth=0;
1022 LogFont.lfEscapement=0;
1023 LogFont.lfOrientation=0;
1024 LogFont.lfWeight=FW_REGULAR;
1025 LogFont.lfItalic=NULL;
1026 LogFont.lfUnderline=0;
1027 LogFont.lfStrikeOut=NULL;
1028 LogFont.lfCharSet=SHIFTJIS_CHARSET;
1029 LogFont.lfOutPrecision=OUT_STRING_PRECIS;
1030 LogFont.lfClipPrecision=CLIP_STROKE_PRECIS;
1031 LogFont.lfQuality=DRAFT_QUALITY;
1032 LogFont.lfPitchAndFamily=VARIABLE_PITCH;
1033 sprintf(LogFont.lfFaceName,"MS ゴシック");
1034 hRulerFont=CreateFontIndirect(&LogFont);
1035
1036 //行番号の描画用
1037 extern HFONT hFont_LineNumber;
1038 LogFont.lfHeight=-11;
1039 LogFont.lfWidth=0;
1040 LogFont.lfEscapement=0;
1041 LogFont.lfOrientation=0;
1042 LogFont.lfWeight=FW_BOLD;
1043 LogFont.lfItalic=NULL;
1044 LogFont.lfUnderline=NULL;
1045 LogFont.lfStrikeOut=NULL;
1046 LogFont.lfCharSet=ANSI_CHARSET;
1047 LogFont.lfOutPrecision=OUT_STRING_PRECIS;
1048 LogFont.lfClipPrecision=CLIP_STROKE_PRECIS;
1049 LogFont.lfQuality=DRAFT_QUALITY;
1050 LogFont.lfPitchAndFamily=VARIABLE_PITCH;
1051 sprintf(LogFont.lfFaceName,"Courier New");
1052 hFont_LineNumber=CreateFontIndirect(&LogFont);
1053
1054 //メニューフォント
1055 NONCLIENTMETRICS NCMetrics;
1056 NCMetrics.cbSize = sizeof( NONCLIENTMETRICS );
1057 SystemParametersInfo( SPI_GETNONCLIENTMETRICS, sizeof( NONCLIENTMETRICS ), &NCMetrics, 0 );
1058 hMenuFont=CreateFontIndirect(&NCMetrics.lfMenuFont);
1059
1060
1061
1062 //背景ブラシ
1063 extern HBRUSH h3DFaceBackBrush;
1064 h3DFaceBackBrush=CreateSolidBrush(GetSysColor(COLOR_3DFACE));
1065
1066 //アイコン
1067 extern HICON hOwnerIcon,hBasicProgramIcon,hTextDocumentIcon,hWindowDocumentIcon;
1068 hOwnerIcon=(HICON)LoadImage(hInst,MAKEINTRESOURCE(IDI_MAIN),IMAGE_ICON,16,16,LR_DEFAULTCOLOR);
1069 hBasicProgramIcon=(HICON)LoadImage(hResInst,MAKEINTRESOURCE(IDI_BASICPROGRAM),IMAGE_ICON,16,16,LR_DEFAULTCOLOR);
1070 hTextDocumentIcon=(HICON)LoadImage(hResInst,MAKEINTRESOURCE(IDI_TEXTDOCUMENT),IMAGE_ICON,16,16,LR_DEFAULTCOLOR);
1071 hWindowDocumentIcon=(HICON)LoadImage(hResInst,MAKEINTRESOURCE(IDI_WINDOW),IMAGE_ICON,16,16,LR_DEFAULTCOLOR);
1072
1073
1074
1075
1076 //メインメニュー
1077 pobj_MainMenu=new CMenuEx(LoadMenu(hResInst,MAKEINTRESOURCE(IDR_MAINMENU)));
1078
1079 pobj_MainMenu->InitOwnerDraw(1); //オーナー描画の初期化
1080
1081 CSubMenuEx *pobj_FileMenu;
1082 pobj_FileMenu=pobj_MainMenu->ppobj_MenuItemData[0]->pobj_SubMenu;
1083
1084 //未完成
1085 extern HMENU hFirstMainMenu;
1086 hFirstMainMenu=0;
1087
1088 //「最近使ったファイル」サブメニューを取得(と同時にも正規のメニュー文字列を指定)
1089 for(i=0;i<pobj_FileMenu->iMenuItemNum;i++){
1090 if(pobj_FileMenu->ppobj_MenuItemData[i]->str){
1091 if(lstrcmp(pobj_FileMenu->ppobj_MenuItemData[i]->str,"FileHistory")==0){
1092 pobj_FileMenu->RenameMenuItem(i,"最近使ったファイル(&F)");
1093
1094 extern CSubMenuEx *pobj_FileHistoryMenu;
1095 pobj_FileHistoryMenu=pobj_FileMenu->ppobj_MenuItemData[i]->pobj_SubMenu;
1096 }
1097
1098#ifndef THETEXT
1099 //「最近使ったプロジェクト」サブメニューを取得(と同時にも正規のメニュー文字列を指定)
1100 //※ProjectEditorのみ
1101 if(lstrcmp(pobj_FileMenu->ppobj_MenuItemData[i]->str,"ProjectHistory")==0){
1102 pobj_FileMenu->RenameMenuItem(i,"最近使ったプロジェクト(&J)");
1103
1104 extern CSubMenuEx *pobj_ProjectHistoryMenu;
1105 pobj_ProjectHistoryMenu=pobj_FileMenu->ppobj_MenuItemData[i]->pobj_SubMenu;
1106 }
1107#endif
1108 }
1109 }
1110
1111#define ICONSET(itemID,iconID) pobj_MainMenu->SetIcon(itemID,(HICON)LoadImage(hIconResInst,MAKEINTRESOURCE(iconID),IMAGE_ICON,16,16,0));
1112 //メニューアイコンをセット
1113
1114 //ファイル
1115 ICONSET(IDM_NEW,IDI_NEW);
1116 ICONSET(IDM_OPEN,IDI_OPEN);
1117 ICONSET(IDM_SAVE,IDI_SAVE);
1118 ICONSET(IDM_ALLSAVE,IDI_ALLSAVE);
1119 ICONSET(IDM_PREVIEW,IDI_PREVIEW);
1120 ICONSET(IDM_PRINTOUT,IDI_PRINT);
1121
1122 //編集
1123 ICONSET(IDM_CUT,IDI_CUT);
1124 ICONSET(IDM_COPY,IDI_COPY);
1125 ICONSET(IDM_PASTE,IDI_PASTE);
1126 ICONSET(IDM_UNDO,IDI_UNDO);
1127 ICONSET(IDM_REDO,IDI_REDO);
1128 ICONSET(IDM_FIND,IDI_FIND);
1129
1130 //表示
1131 ICONSET(IDM_SET,IDI_OPTION);
1132
1133 //変換
1134 ICONSET(IDM_CONV_ALPHA_SMALL,IDI_CONV_ALPHA_SMALL);
1135 ICONSET(IDM_CONV_ALPHA_BIG,IDI_CONV_ALPHA_BIG);
1136 ICONSET(IDM_CONV_HALF,IDI_CONV_HALF);
1137 ICONSET(IDM_CONV_MULTI,IDI_CONV_MULTI);
1138 ICONSET(IDM_CONV_KATAKANA,IDI_CONV_KATAKANA);
1139 ICONSET(IDM_CONV_HIRAGANA,IDI_CONV_HIRAGANA);
1140
1141 //ヘルプ
1142 ICONSET(IDM_TOPIC,IDI_HELP);
1143
1144#ifdef THETEXT
1145 //TheTextのみの機能
1146 ICONSET(IDM_STRING_COUNT,IDI_STRINGCOUNT);
1147#else
1148 //ProjectEditorのみの機能
1149
1150 //リリース
1151 ICONSET(IDM_RELEASECOMPILE,IDI_RELEASECOMPILE);
1152 ICONSET(IDM_RELEASERUN,IDI_RELEASERUN);
1153
1154 //デバッグ
1155 ICONSET(IDM_ATTACH,IDI_ATTACH);
1156 ICONSET(IDM_DEBUGCOMPILE,IDI_DEBUGCOMPILE);
1157 ICONSET(IDM_DEBUG,IDI_DEBUGRUN);
1158 ICONSET(IDM_BREAKPOINT,IDI_BREAKPOINT);
1159 ICONSET(IDM_STEP_IN,IDI_STEPIN);
1160 ICONSET(IDM_STEP_OVER,IDI_STEPOVER);
1161 ICONSET(IDM_STEP_CURSOR,IDI_STEPTOCURSOR);
1162 ICONSET(IDM_DEBUG_PAUSE,IDI_DEBUGPAUSE);
1163 ICONSET(IDM_DEBUG_STOP,IDI_DEBUGSTOP);
1164
1165 //コミュニティ
1166 ICONSET(IDM_COMMUNITY,IDI_COMMUNITY_MAIN);
1167 ICONSET(IDM_COMMU_SEARCH,IDI_COMMUNITY_FIND);
1168 ICONSET(IDM_COMMU_PM,IDI_COMMUNITY_PRIVATEMSG);
1169 ICONSET(ID_COMMU_FORUM1,IDI_COMMUNITY_FORUM);
1170 ICONSET(ID_COMMU_FORUM2,IDI_COMMUNITY_FORUM);
1171 ICONSET(ID_COMMU_FORUM3,IDI_COMMUNITY_FORUM);
1172 ICONSET(ID_COMMU_FORUM4,IDI_COMMUNITY_FORUM);
1173 ICONSET(ID_COMMU_FORUM5,IDI_COMMUNITY_FORUM);
1174 ICONSET(ID_COMMU_FORUM6,IDI_COMMUNITY_FORUM_SECRET);
1175 ICONSET(ID_COMMU_FORUM7,IDI_COMMUNITY_FORUM);
1176 ICONSET(ID_COMMU_FORUM8,IDI_COMMUNITY_FORUM);
1177#endif
1178
1179#undef ICONSET
1180
1181
1182
1183
1184 extern HMENU hEditMenuBase,hEditMenu;
1185 hEditMenuBase=LoadMenu(hResInst,MAKEINTRESOURCE(IDR_EDITMENU));
1186 hEditMenu=GetSubMenu(hEditMenuBase,0);
1187
1188 extern HMENU hRebarMenuBase,hRebarMenu;
1189 hRebarMenuBase=LoadMenu(hResInst,MAKEINTRESOURCE(IDR_REBARMENU));
1190 hRebarMenu=GetSubMenu(hRebarMenuBase,0);
1191
1192 extern HMENU hTabMenuBase,hTabMenu,hTabColorMenu;
1193 hTabMenuBase=LoadMenu(hResInst,MAKEINTRESOURCE(IDR_TABMENU));
1194 hTabMenu=GetSubMenu(hTabMenuBase,0);
1195 hTabColorMenu=GetSubMenu(hTabMenu,0);
1196
1197 extern HMENU hFileTreeMenuBase;
1198 hFileTreeMenuBase=LoadMenu(hResInst,MAKEINTRESOURCE(IDR_PROJECTVIEW_FILETREEMENU));
1199
1200 extern HMENU hProcedureTreeMenuBase;
1201 hProcedureTreeMenuBase=LoadMenu(hResInst,MAKEINTRESOURCE(IDR_PROJECTVIEW_PROCEDURETREEMENU));
1202
1203 extern HMENU hMaterialTreeMenuBase;
1204 hMaterialTreeMenuBase=LoadMenu(hResInst,MAKEINTRESOURCE(IDR_PROJECTVIEW_MATERIALTREEMENU));
1205
1206 extern HMENU hRadMenuBase;
1207 hRadMenuBase=LoadMenu(hResInst,MAKEINTRESOURCE(IDR_RADCONTEXTMENU));
1208
1209 //クリップボードのデータ形式(RAD用)を新規登録
1210 extern DWORD dwRadClipboardID;
1211 dwRadClipboardID=RegisterClipboardFormat("ProjectEditor-RAD");
1212
1213 //256色の標準パレットを読み込む
1214 extern RGBQUAD DefaultColorTable256[256];
1215 HANDLE hFile;
1216 DWORD dw;
1217 sprintf(temporary,"%sSubOperation\\8bit.plt",pj_editor_Dir);
1218 hFile=CreateFile(temporary,GENERIC_READ,FILE_SHARE_READ|FILE_SHARE_WRITE,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);
1219 if(hFile==INVALID_HANDLE_VALUE){
1220 //"\"%s\" ファイルの読み込みに失敗しました。"
1221 sprintf(str,STRING_ERROR_CANT_FILEOPEN,temporary);
1222 MessageBox(NULL,str,STRING_ERROR,MB_OK|MB_ICONEXCLAMATION);
1223 return 0;
1224 }
1225 ReadFile(hFile,DefaultColorTable256,sizeof(RGBQUAD)*256,&dw,NULL);
1226 CloseHandle(hFile);
1227
1228
1229
1230 //デザインテーマオブジェクトを生成
1231 pobj_DBTheme=new CDBTheme();
1232
1233
1234 /////////////////////////
1235 // カラーデザインを設定
1236 CTheme *pobj_Theme;
1237 pobj_Theme=pobj_DBTheme->GetActiveTheme();
1238 if(!pobj_Theme) pobj_Theme=pobj_DBTheme->ppobj_Theme[0];
1239
1240 SetTextEditColorDesign(&tci,pobj_Theme,0);
1241
1242
1243#ifndef THETEXT
1244 /////////////////////////////////////////////////////
1245 // ProjectEditorのみ
1246 /////////////////////////////////////////////////////
1247
1248
1249 //クラスビュー管理オブジェクトを生成
1250 pobj_ClassTreeView=new CClassTreeView();
1251
1252
1253 /////////////////////////
1254 // basic.sbpの内容を取得
1255 /////////////////////////
1256
1257 extern char *pHeaderBuf;
1258 sprintf(temporary,"%sbasic.sbp",pobj_nv->szIncludeDir);
1259 GetFullPath( temporary, pj_editor_Dir );
1260 pHeaderBuf=ReadBuffer(temporary);
1261
1262 if( !pHeaderBuf ){
1263 pHeaderBuf=(char *)HeapAlloc(hHeap,HEAP_ZERO_MEMORY,1);
1264 }
1265
1266 //ファイルをインクルード
1267 pHeaderBuf=IncludeFiles(pHeaderBuf);
1268
1269
1270 //デバッガ管理オブジェクトを生成
1271 pobj_Debugger=new CDebugger();
1272#endif
1273
1274
1275 //ブレークポイント管理オブジェクトを生成
1276 extern CDBBreakPoint *pobj_DBBreakPoint;
1277 pobj_DBBreakPoint=new CDBBreakPoint();
1278
1279
1280 return 1;
1281}
1282void EndProjectEditor(void){
1283
1284#ifndef THETEXT
1285 /////////////////////////////////////////////////////
1286 // ProjectEditorのみ
1287 /////////////////////////////////////////////////////
1288
1289
1290 //クラスビュー管理オブジェクトを破棄
1291 delete pobj_ClassTreeView;
1292 pobj_ClassTreeView=0;
1293
1294 //basic.sbpのソースコードバッファを解放
1295 extern char *pHeaderBuf;
1296 HeapDefaultFree(pHeaderBuf);
1297
1298 //デバッガ管理オブジェクトを破棄
1299 delete pobj_Debugger;
1300#endif
1301
1302 //ブレークポイント管理オブジェクトを破棄
1303 extern CDBBreakPoint *pobj_DBBreakPoint;
1304 delete pobj_DBBreakPoint;
1305
1306 //デザインテーマオブジェクトを破棄
1307 delete pobj_DBTheme;
1308
1309 //不揮発性のデータを保存
1310 pobj_nv->save();
1311 delete pobj_nv;
1312 pobj_nv=0;
1313
1314 //メインメニューオブジェクトを破棄
1315 delete pobj_MainMenu;
1316 pobj_MainMenu=0;
1317
1318 extern HFONT hStatusFont;
1319 DeleteObject(hStatusFont);
1320 extern HFONT hHyperLinkFont;
1321 DeleteObject(hHyperLinkFont);
1322 extern HFONT hRulerFont;
1323 DeleteObject(hRulerFont);
1324 extern HFONT hFont_LineNumber;
1325 DeleteObject(hFont_LineNumber);
1326 extern METHODCHECKINFO MethodCheckInfo;
1327 DeleteObject(MethodCheckInfo.hFont);
1328 DeleteObject(MethodCheckInfo.hBoldFont);
1329 extern HICON hOwnerIcon,hBasicProgramIcon,hTextDocumentIcon,hWindowDocumentIcon;
1330 DestroyIcon(hOwnerIcon);
1331 DestroyIcon(hBasicProgramIcon);
1332 DestroyIcon(hTextDocumentIcon);
1333 DestroyIcon(hWindowDocumentIcon);
1334 extern HMENU hEditMenuBase,hRebarMenuBase,hTabMenuBase;
1335 DestroyMenu(hEditMenuBase);
1336 DestroyMenu(hRebarMenuBase);
1337 DestroyMenu(hTabMenuBase);
1338 extern HMENU hFileTreeMenuBase;
1339 DestroyMenu(hFileTreeMenuBase);
1340 extern HMENU hProcedureTreeMenuBase;
1341 DestroyMenu(hProcedureTreeMenuBase);
1342 extern HMENU hMaterialTreeMenuBase;
1343 DestroyMenu(hMaterialTreeMenuBase);
1344 extern HMENU hRadMenuBase;
1345 DestroyMenu(hRadMenuBase);
1346
1347 //背景ブラシ
1348 extern HBRUSH h3DFaceBackBrush;
1349 DeleteObject(h3DFaceBackBrush);
1350
1351 //スタンダードツールバーを破棄
1352 if(pobj_StandardToolbar){
1353 pobj_StandardToolbar->Release();
1354 pobj_StandardToolbar=0;
1355 }
1356
1357 //ビルドツールバーを破棄
1358 if(pobj_ReleaseToolbar){
1359 pobj_ReleaseToolbar->Release();
1360 pobj_ReleaseToolbar=0;
1361 }
1362
1363 //デバッガ用ツールバーを破棄
1364 if(pobj_DebuggerToolbar){
1365 pobj_DebuggerToolbar->Release();
1366 pobj_DebuggerToolbar=0;
1367 }
1368
1369 //ヒープオブジェクトを解放
1370 extern HANDLE hHeap;
1371 HeapDestroy(hHeap);
1372
1373 //DLLを解放
1374 FreeLibrary(hResInst);
1375 FreeLibrary(hIconResInst);
1376 FreeLibrary(hLib_LuxCtrl);
1377
1378 //アルファブレンド用のAPIを解放
1379 extern HINSTANCE hUser32Lib;
1380 FreeLibrary(hUser32Lib);
1381
1382
1383
1384
1385 //////////////////////////////////////
1386 // バックアップ用ファイルを削除
1387 //////////////////////////////////////
1388 extern char szBackupDirPath[MAX_PATH];
1389 RemoveDirectoryStrong(szBackupDirPath);
1390
1391}
1392
1393//各ウィンドウ生成
1394void SetupWindow(HWND hwnd){
1395 extern HINSTANCE hInst;
1396 extern HMENU hFirstMainMenu;
1397 RECT rect;
1398 CLIENTCREATESTRUCT ccs;
1399
1400 INITCOMMONCONTROLSEX InitCommCtrl;
1401 InitCommCtrl.dwSize=sizeof(INITCOMMONCONTROLSEX);
1402 InitCommCtrl.dwICC=ICC_COOL_CLASSES|ICC_PAGESCROLLER_CLASS|ICC_WIN95_CLASSES|ICC_TAB_CLASSES;
1403 InitCommonControlsEx(&InitCommCtrl);
1404
1405 //タブウィンドウ
1406 pobj_MainTab=new CMainTab(hwnd);
1407
1408 //MDIの親ウィンドウ(クライアントウィンドウ)を作成
1409 ccs.hWindowMenu=hFirstMainMenu;
1410 ccs.idFirstChild=ID_FIRSTCHILD;
1411 GetClientRect(hwnd,&rect);
1412 hClient=CreateWindowEx(WS_EX_CLIENTEDGE,"MDICLIENT",NULL,
1413 WS_CHILD|WS_CLIPCHILDREN|WS_CLIPSIBLINGS|WS_VISIBLE,
1414 0,0,0,0,
1415 hwnd,(HMENU)1,hInst,(LPSTR)&ccs);
1416
1417 //レバーオブジェクトを生成
1418 pobj_Rebar=new CMainRebar(hwnd);
1419
1420 //ステータスバー
1421 extern HWND hStatusBar;
1422 extern HFONT hStatusFont;
1423 hStatusBar=CreateStatusWindow(
1424 WS_VISIBLE|WS_CHILD|WS_CLIPSIBLINGS|SBARS_SIZEGRIP|CCS_BOTTOM,
1425 NULL,hwnd,NULL);
1426 SendMessage(hStatusBar,WM_SETFONT,(long)hStatusFont,0);
1427
1428 //プロジェクト ビュー
1429 extern HWND hProjectView;
1430 extern HWND hProjectView_ToolWindow;
1431 RECT *prc;
1432 prc=&pobj_nv->rectProjectView;
1433 hProjectView_ToolWindow=CreateWindowEx(WS_EX_TOOLWINDOW,"ProjectView_ToolWindow","ProjectView",
1434 WS_POPUP|WS_CAPTION|WS_SYSMENU|WS_THICKFRAME|WS_CLIPCHILDREN,
1435 prc->left,prc->top,prc->right-prc->left,prc->bottom-prc->top,
1436 hwnd,0,hInst,0);
1437 hProjectView=CreateWindowEx(WS_EX_STATICEDGE,"ProjectView","ProjectView",
1438 WS_CHILD|WS_CLIPCHILDREN,
1439 0,0,0,0,
1440 hwnd,0,hInst,0);
1441 if(pobj_nv->bClipProjectView==0){
1442 SetWindowLongPtr(hProjectView,GWL_EXSTYLE,0);
1443 SetParent(hProjectView,hProjectView_ToolWindow);
1444 ResizeProjectView_ToolWindow();
1445 }
1446
1447 //メニュー状態を設定
1448 ResetState_DocMenu();
1449
1450
1451 //SideWebを生成
1452 pobj_SideWeb=new CSideWeb(hwnd);
1453}
1454
1455//実行コマンド
1456BOOL SetRunning(HWND hChild){
1457 extern MDIINFO MdiInfo[MAX_WNDNUM];
1458 extern LPSTR DefFileFilter;
1459 int WndNum;
1460 char temporary[MAX_PATH],temp2[MAX_PATH];
1461 HANDLE hFind;
1462 WIN32_FIND_DATA wfd;
1463
1464 extern char *lpszCompilerName;
1465 sprintf(temporary,"%s%s",pj_editor_Dir,lpszCompilerName);
1466 hFind=FindFirstFile(temporary,&wfd);
1467 if(hFind==INVALID_HANDLE_VALUE){
1468 //"BasicCompiler.exe が見つかりません"
1469 MessageBox(hOwner,STRING_ERROR_NOBASICCOMPILER,STRING_ERROR,MB_OK|MB_ICONEXCLAMATION);
1470 return FALSE;
1471 }
1472 FindClose(hFind);
1473
1474 WndNum=GetWndNum(hChild);
1475 if(IS_DOCUMENT_TEXT(MdiInfo[WndNum].DocType)){
1476 if(MdiInfo[WndNum].path[0]=='\0'){
1477 //"保存先のファイルを指定してください"
1478 if(!GetFilePathDialog(hOwner,temp2,DefFileFilter,STRING_FILESAVETITLE_DEFAULT,0)) return FALSE;
1479
1480 if(!SaveDocument(hChild,temp2)) return 0;
1481 }
1482 else{
1483 if( MdiInfo[WndNum].pMdiTextEdit->IsModified() ){
1484 if(!SaveDocument(hChild,NULL)) return 0;
1485 }
1486 else{
1487 if(hFind=FindFirstFile(MdiInfo[WndNum].path,&wfd)){
1488 if(hFind==INVALID_HANDLE_VALUE){
1489 if(!SaveDocument(hChild,NULL)) return 0;
1490 }
1491 else FindClose(hFind);
1492 }
1493 }
1494 }
1495 }
1496 return 1;
1497}
1498
1499BOOL IsNeedCompile(char *FileName,BOOL bDebug){
1500 char temporary[MAX_PATH],temp2[MAX_PATH],temp3[MAX_PATH];
1501 HANDLE hFind,hFile;
1502 WIN32_FIND_DATA wfd;
1503 FILETIME SourceTime,ExeTime;
1504
1505 _splitpath(FileName,temporary,temp2,temp3,NULL);
1506 lstrcat(temporary,temp2);
1507 lstrcat(temporary,temp3);
1508 if(bDebug) lstrcat(temporary,"_debug.exe");
1509 else lstrcat(temporary,".exe");
1510
1511 hFind=FindFirstFile(temporary,&wfd);
1512 if(hFind==INVALID_HANDLE_VALUE) return 1;
1513 FindClose(hFind);
1514
1515 hFile=CreateFile(FileName,GENERIC_READ,FILE_SHARE_READ|FILE_SHARE_WRITE,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);
1516 GetFileTime(hFile,NULL,NULL,&SourceTime);
1517 CloseHandle(hFile);
1518
1519 hFile=CreateFile(temporary,GENERIC_READ,FILE_SHARE_READ|FILE_SHARE_WRITE,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);
1520 GetFileTime(hFile,NULL,NULL,&ExeTime);
1521 CloseHandle(hFile);
1522
1523 if(SourceTime.dwHighDateTime<ExeTime.dwHighDateTime) return 0;
1524 else if(SourceTime.dwHighDateTime==ExeTime.dwHighDateTime&&
1525 SourceTime.dwLowDateTime<=ExeTime.dwLowDateTime) return 0;
1526 return 1;
1527}
1528
1529string GetLastErrorString(){
1530 char *lpMsgBuf;
1531
1532 FormatMessage(
1533 FORMAT_MESSAGE_ALLOCATE_BUFFER |
1534 FORMAT_MESSAGE_FROM_SYSTEM |
1535 FORMAT_MESSAGE_IGNORE_INSERTS,
1536 NULL,
1537 GetLastError(),
1538 MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // デフォルト言語
1539 (LPTSTR) &lpMsgBuf,
1540 0,
1541 NULL
1542 );
1543
1544 string result = lpMsgBuf;
1545
1546 LocalFree( lpMsgBuf );
1547
1548 return result;
1549}
Note: See TracBrowser for help on using the repository browser.