2f64c1e2964a59f6b879ce3ceba389dc82e2a7f9
[sdk] / compiler / bootstrap / ecere / bootstrap / String.c
1 #if defined(__GNUC__)
2 typedef long long int64;
3 typedef unsigned long long uint64;
4 #ifndef _WIN32
5 #define __declspec(x)
6 #endif
7 #elif defined(__TINYC__)
8 #include <stdarg.h>
9 #define __builtin_va_list va_list
10 #define __builtin_va_start va_start
11 #define __builtin_va_end va_end
12 #ifdef _WIN32
13 #define strcasecmp stricmp
14 #define strncasecmp strnicmp
15 #define __declspec(x) __attribute__((x))
16 #else
17 #define __declspec(x)
18 #endif
19 typedef long long int64;
20 typedef unsigned long long uint64;
21 #else
22 typedef __int64 int64;
23 typedef unsigned __int64 uint64;
24 #endif
25 #ifdef __BIG_ENDIAN__
26 #define __ENDIAN_PAD(x) (8 - (x))
27 #else
28 #define __ENDIAN_PAD(x) 0
29 #endif
30 #include <stdint.h>
31 extern void *  __ecereNameSpace__ecere__com__eSystem_New(unsigned int size);
32
33 extern void *  __ecereNameSpace__ecere__com__eSystem_New0(unsigned int size);
34
35 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew(void *  memory, unsigned int size);
36
37 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew0(void *  memory, unsigned int size);
38
39 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BTNode;
40
41 struct __ecereNameSpace__ecere__sys__BTNode;
42
43 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BinaryTree;
44
45 struct __ecereNameSpace__ecere__sys__BinaryTree
46 {
47 struct __ecereNameSpace__ecere__sys__BTNode * root;
48 int count;
49 int (*  CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
50 void (*  FreeKey)(void *  key);
51 } __attribute__ ((gcc_struct));
52
53 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__OldList;
54
55 struct __ecereNameSpace__ecere__sys__OldList
56 {
57 void *  first;
58 void *  last;
59 int count;
60 unsigned int offset;
61 unsigned int circ;
62 } __attribute__ ((gcc_struct));
63
64 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Class;
65
66 struct __ecereNameSpace__ecere__com__Class
67 {
68 struct __ecereNameSpace__ecere__com__Class * prev;
69 struct __ecereNameSpace__ecere__com__Class * next;
70 char *  name;
71 int offset;
72 int structSize;
73 int (* *  _vTbl)();
74 int vTblSize;
75 int (*  Constructor)(struct __ecereNameSpace__ecere__com__Instance *);
76 void (*  Destructor)(struct __ecereNameSpace__ecere__com__Instance *);
77 int offsetClass;
78 int sizeClass;
79 struct __ecereNameSpace__ecere__com__Class * base;
80 struct __ecereNameSpace__ecere__sys__BinaryTree methods;
81 struct __ecereNameSpace__ecere__sys__BinaryTree members;
82 struct __ecereNameSpace__ecere__sys__BinaryTree prop;
83 struct __ecereNameSpace__ecere__sys__OldList membersAndProperties;
84 struct __ecereNameSpace__ecere__sys__BinaryTree classProperties;
85 struct __ecereNameSpace__ecere__sys__OldList derivatives;
86 int memberID;
87 int startMemberID;
88 int type;
89 struct __ecereNameSpace__ecere__com__Instance * module;
90 struct __ecereNameSpace__ecere__com__NameSpace *  nameSpace;
91 char *  dataTypeString;
92 struct __ecereNameSpace__ecere__com__Instance * dataType;
93 int typeSize;
94 int defaultAlignment;
95 void (*  Initialize)();
96 int memberOffset;
97 struct __ecereNameSpace__ecere__sys__OldList selfWatchers;
98 char *  designerClass;
99 unsigned int noExpansion;
100 char *  defaultProperty;
101 unsigned int comRedefinition;
102 int count;
103 unsigned int isRemote;
104 unsigned int internalDecl;
105 void *  data;
106 unsigned int computeSize;
107 int structAlignment;
108 int destructionWatchOffset;
109 unsigned int fixed;
110 struct __ecereNameSpace__ecere__sys__OldList delayedCPValues;
111 int inheritanceAccess;
112 char *  fullName;
113 void *  symbol;
114 struct __ecereNameSpace__ecere__sys__OldList conversions;
115 struct __ecereNameSpace__ecere__sys__OldList templateParams;
116 struct __ecereNameSpace__ecere__com__ClassTemplateArgument *  templateArgs;
117 struct __ecereNameSpace__ecere__com__Class * templateClass;
118 struct __ecereNameSpace__ecere__sys__OldList templatized;
119 int numParams;
120 } __attribute__ ((gcc_struct));
121
122 extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, char *  name);
123
124 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Instance;
125
126 struct __ecereNameSpace__ecere__com__Instance
127 {
128 int (* *  _vTbl)();
129 struct __ecereNameSpace__ecere__com__Class * _class;
130 int _refCount;
131 } __attribute__ ((gcc_struct));
132
133 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Property;
134
135 struct __ecereNameSpace__ecere__com__Property
136 {
137 struct __ecereNameSpace__ecere__com__Property * prev;
138 struct __ecereNameSpace__ecere__com__Property * next;
139 char *  name;
140 unsigned int isProperty;
141 int memberAccess;
142 int id;
143 struct __ecereNameSpace__ecere__com__Class * _class;
144 char *  dataTypeString;
145 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
146 struct __ecereNameSpace__ecere__com__Instance * dataType;
147 void (*  Set)(void * , int);
148 int (*  Get)(void * );
149 unsigned int (*  IsSet)(void * );
150 void *  data;
151 void *  symbol;
152 int vid;
153 unsigned int conversion;
154 unsigned int watcherOffset;
155 char *  category;
156 unsigned int compiled;
157 unsigned int selfWatchable;
158 unsigned int isWatchable;
159 } __attribute__ ((gcc_struct));
160
161 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataMember;
162
163 struct __ecereNameSpace__ecere__com__DataMember
164 {
165 struct __ecereNameSpace__ecere__com__DataMember * prev;
166 struct __ecereNameSpace__ecere__com__DataMember * next;
167 char *  name;
168 unsigned int isProperty;
169 int memberAccess;
170 int id;
171 struct __ecereNameSpace__ecere__com__Class * _class;
172 char *  dataTypeString;
173 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
174 struct __ecereNameSpace__ecere__com__Instance * dataType;
175 int type;
176 int offset;
177 int memberID;
178 struct __ecereNameSpace__ecere__sys__OldList members;
179 struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha;
180 int memberOffset;
181 int structAlignment;
182 } __attribute__ ((gcc_struct));
183
184 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Method;
185
186 struct __ecereNameSpace__ecere__com__Method
187 {
188 char *  name;
189 struct __ecereNameSpace__ecere__com__Method * parent;
190 struct __ecereNameSpace__ecere__com__Method * left;
191 struct __ecereNameSpace__ecere__com__Method * right;
192 int depth;
193 int (*  function)();
194 int vid;
195 int type;
196 struct __ecereNameSpace__ecere__com__Class * _class;
197 void *  symbol;
198 char *  dataTypeString;
199 struct __ecereNameSpace__ecere__com__Instance * dataType;
200 int memberAccess;
201 } __attribute__ ((gcc_struct));
202
203 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__SerialBuffer;
204
205 struct __ecereNameSpace__ecere__com__SerialBuffer
206 {
207 unsigned char *  _buffer;
208 unsigned int count;
209 unsigned int _size;
210 unsigned int pos;
211 } __attribute__ ((gcc_struct));
212
213 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataValue;
214
215 struct __ecereNameSpace__ecere__com__DataValue
216 {
217 union
218 {
219 char c;
220 unsigned char uc;
221 short s;
222 unsigned short us;
223 int i;
224 unsigned int ui;
225 void *  p;
226 float f;
227 double d;
228 long long i64;
229 uint64 ui64;
230 } __attribute__ ((gcc_struct));
231 } __attribute__ ((gcc_struct));
232
233 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__ClassTemplateArgument;
234
235 struct __ecereNameSpace__ecere__com__ClassTemplateArgument
236 {
237 union
238 {
239 struct
240 {
241 char *  dataTypeString;
242 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
243 } __attribute__ ((gcc_struct));
244 struct __ecereNameSpace__ecere__com__DataValue expression;
245 struct
246 {
247 char *  memberString;
248 union
249 {
250 struct __ecereNameSpace__ecere__com__DataMember * member;
251 struct __ecereNameSpace__ecere__com__Property * prop;
252 struct __ecereNameSpace__ecere__com__Method * method;
253 } __attribute__ ((gcc_struct));
254 } __attribute__ ((gcc_struct));
255 } __attribute__ ((gcc_struct));
256 } __attribute__ ((gcc_struct));
257
258 typedef uintptr_t size_t;
259
260 void exit(int status);
261
262 void * calloc(size_t nmemb, size_t size);
263
264 void free(void * ptr);
265
266 void * malloc(size_t size);
267
268 void * realloc(void * ptr, size_t size);
269
270 long int strtol(const char * nptr, char ** endptr, int base);
271
272 long long int strtoll(const char * nptr, char ** endptr, int base);
273
274 unsigned long long int strtoull(const char * nptr, char ** endptr, int base);
275
276 extern int runtimePlatform;
277
278
279
280
281
282
283
284
285 extern int strlen(const char * );
286
287 extern char *  strcpy(char * , const char * );
288
289 char * __ecereNameSpace__ecere__sys__GetExtension(char * string, char * output)
290 {
291 int __simpleStruct0;
292 int c;
293 int len = strlen(string);
294 int limit = (__simpleStruct0 = len - (17), (0 > __simpleStruct0) ? 0 : __simpleStruct0);
295
296 output[0] = '\0';
297 for(c = len; c >= limit; c--)
298 {
299 char ch = string[c];
300
301 if(ch == '.')
302 {
303 strcpy(output, string + c + 1);
304 break;
305 }
306 else if(ch == '/' || ch == '\\')
307 break;
308 }
309 return output;
310 }
311
312 extern int strcmp(const char * , const char * );
313
314 extern void *  memmove(void * , const void * , unsigned int size);
315
316 extern int __ecereNameSpace__ecere__com__GetRuntimePlatform(void);
317
318 char * __ecereNameSpace__ecere__sys__StripLastDirectory(char * string, char * output)
319 {
320 int c;
321
322 if(runtimePlatform == 1 && !strcmp(string, "\\\\"))
323 {
324 strcpy(output, "/");
325 return output;
326 }
327 else
328 {
329 int len = strlen(string);
330
331 for(c = len - 2; c >= 0; c--)
332 if(string[c] == '/' || string[c] == '\\')
333 break;
334 else if(string[c] == '>' || (string[c] == ':' && c == 0))
335 {
336 c++;
337 break;
338 }
339 if((runtimePlatform == 1) ? (c >= 0) : (c > 0))
340 {
341 memmove(output, string, c);
342 if(c > 0)
343 {
344 if(runtimePlatform == 1 && c == 1 && output[0] == '\\' && output[1] == '\\')
345 output[2] = '\0';
346 else
347 output[c] = '\0';
348 }
349 else
350 strcpy(output, ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? "\\" : "/"));
351 return output;
352 }
353 else
354 {
355 if(c == 0)
356 {
357 strcpy(output, ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? "\\" : "/"));
358 return output;
359 }
360 else
361 {
362 strcpy(output, "");
363 return (((void *)0));
364 }
365 }
366 }
367 }
368
369 char * __ecereNameSpace__ecere__sys__SplitDirectory(const char * string, char * part, char * rest)
370 {
371 int len = 0;
372 char ch;
373 int c = 0;
374
375 for(; (ch = string[c]) && (ch == '/' || ch == '\\'); c++)
376 ;
377 if(c)
378 part[len++] = ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? '\\' : '/');
379 else
380 {
381 for(; (ch = string[c]) && (ch != '/' && ch != '\\'); c++)
382 {
383 if(len < (274))
384 part[len++] = ch;
385 }
386 }
387 for(; (ch = string[c]) && (ch == '/' || ch == '\\'); c++)
388 ;
389 memmove(rest, string + c, strlen(string + c) + 1);
390 for(c = strlen(rest); c >= 0; c--)
391 if(ch != '/' && ch != '\\')
392 break;
393 if(c > 0)
394 rest[c] = '\0';
395 part[len] = '\0';
396 return rest;
397 }
398
399 char * __ecereNameSpace__ecere__sys__GetLastDirectory(char * string, char * output)
400 {
401 int c;
402 int len = string ? strlen(string) : 0;
403
404 for(c = len - 2; c >= 0; c--)
405 if(string[c] == '/' || string[c] == '\\' || string[c] == ':' || string[c] == '>')
406 break;
407 c++;
408 if(c >= 0)
409 memmove(output, string + c, strlen(string + c) + 1);
410 else
411 output[0] = '\0';
412 len = strlen(output);
413 if(len > 1 && (output[len - 1] == '\\' || output[len - 1] == '/'))
414 output[len - 1] = '\0';
415 return output;
416 }
417
418 extern char *  strncpy(char * , const char * , int n);
419
420 unsigned int __ecereNameSpace__ecere__sys__SplitArchivePath(char * fileName, char * archiveName, char ** archiveFile)
421 {
422 if(fileName[0] == '<')
423 {
424 int c = strlen(fileName);
425
426 for(; c > 0 && fileName[c] != '>'; c--)
427 ;
428 if(c > 0)
429 {
430 strncpy(archiveName, fileName + 1, c - 1);
431 archiveName[c - 1] = '\0';
432 *archiveFile = fileName + c + 1;
433 return 0x1;
434 }
435 }
436 else if(fileName[0] == ':')
437 {
438 strcpy(archiveName, ":");
439 *archiveFile = fileName + 1;
440 return 0x1;
441 }
442 return 0x0;
443 }
444
445 extern char *  strstr(char * , const char * );
446
447 extern int toupper(int);
448
449 extern char *  strcat(char * , const char * );
450
451 extern int sprintf(char * , char * , ...);
452
453 char * __ecereNameSpace__ecere__sys__PathCatSlash(char * string, char * addedPath)
454 {
455 unsigned int modified = 0x0;
456
457 if(addedPath)
458 {
459 char fileName[797] = "", archiveName[797] = "", * file;
460 int c = 0;
461 unsigned int isURL = 0x0;
462 char * urlFileName;
463
464 if(__ecereNameSpace__ecere__sys__SplitArchivePath(string, archiveName, &file))
465 strcpy(fileName, file);
466 else
467 {
468 strcpy(fileName, string);
469 }
470 if(strstr(string, "http://") == string)
471 {
472 char * slash = strstr(fileName + 7, "/");
473
474 isURL = 0x1;
475 if(slash)
476 urlFileName = slash;
477 else
478 urlFileName = fileName + strlen(fileName);
479 }
480 if(strstr(addedPath, "http://") == addedPath)
481 {
482 strcpy(fileName, "http://");
483 isURL = 0x1;
484 c = 7;
485 }
486 else if(__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1)
487 {
488 if(addedPath[0] && addedPath[1] == ':' && addedPath[0] != '<')
489 {
490 fileName[0] = (char)toupper(addedPath[0]);
491 fileName[1] = ':';
492 fileName[2] = '\0';
493 c = 2;
494 modified = 0x1;
495 }
496 else if(addedPath[0] == '\\' && addedPath[1] == '\\')
497 {
498 fileName[0] = fileName[1] = '\\';
499 fileName[2] = '\0';
500 c = 2;
501 modified = 0x1;
502 }
503 }
504 if(!modified && isURL && (addedPath[0] == '\\' || addedPath[0] == '/'))
505 {
506 urlFileName[0] = '/';
507 urlFileName[1] = '\0';
508 }
509 else if(!modified && (addedPath[0] == '\\' || addedPath[0] == '/'))
510 {
511 if(__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1)
512 {
513 if(addedPath[0] == '/' && !addedPath[1])
514 {
515 fileName[0] = addedPath[0];
516 fileName[1] = '\0';
517 modified = 0x1;
518 }
519 else if(fileName[0] && fileName[1] == ':')
520 {
521 fileName[2] = '\0';
522 modified = 0x1;
523 }
524 else
525 {
526 fileName[0] = '\\';
527 fileName[1] = '\0';
528 modified = 0x1;
529 }
530 }
531 else
532 {
533 fileName[0] = '/';
534 fileName[1] = '\0';
535 modified = 0x1;
536 }
537 c = 1;
538 }
539 for(; addedPath[c]; )
540 {
541 char directory[4384LL];
542 int len = 0;
543 char ch;
544 int count;
545
546 for(; (ch = addedPath[c]) && (ch == '/' || ch == '\\'); c++)
547 ;
548 for(; (ch = addedPath[c]) && (ch != '/' && ch != '\\'); c++)
549 {
550 if(isURL && ch == '?')
551 {
552 break;
553 }
554 if(len < (274))
555 directory[len++] = ch;
556 }
557 directory[len] = '\0';
558 for(count = len - 1; count >= 0 && (directory[count] == ' ' || directory[count] == '\t'); count--)
559 {
560 directory[count] = '\0';
561 len--;
562 }
563 if(len > 0)
564 {
565 modified = 0x1;
566 if(strstr(directory, "..") == directory && (!directory[2] || directory[2] == ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? '\\' : '/') || directory[2] == '/'))
567 {
568 int strLen = strlen(fileName) - 1;
569
570 if(strLen > -1)
571 {
572 for(; (ch = fileName[strLen]) && strLen > -1 && (ch == '/' || ch == '\\'); strLen--)
573 ;
574 for(; (ch = fileName[strLen]) && strLen > -1 && (ch != '/' && ch != '\\' && ch != ':'); strLen--)
575 ;
576 for(; (ch = fileName[strLen]) && strLen > -1 && (ch == '/' || ch == '\\'); strLen--)
577 ;
578 if(isURL)
579 {
580 int __simpleStruct0;
581
582 strLen = (__simpleStruct0 = urlFileName - fileName, (strLen > __simpleStruct0) ? strLen : __simpleStruct0);
583 }
584 if(!strcmp(fileName + strLen + 1, ".."))
585 {
586 strcat(fileName, "/");
587 strcat(fileName, "..");
588 }
589 else
590 {
591 if(__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1)
592 {
593 if(!strLen && fileName[0] == '\\' && fileName[1] == '\\')
594 {
595 if(!fileName[2])
596 return (((void *)0));
597 else
598 {
599 fileName[0] = '\\';
600 fileName[1] = '\\';
601 fileName[2] = '\0';
602 }
603 }
604 else
605 fileName[strLen + 1] = '\0';
606 }
607 else
608 {
609 fileName[strLen + 1] = '\0';
610 if(strLen < 0)
611 {
612 fileName[0] = '/';
613 fileName[1] = '\0';
614 strLen = 2;
615 }
616 }
617 }
618 }
619 else
620 {
621 strcpy(fileName, "..");
622 }
623 }
624 else if(strcmp(directory, "."))
625 {
626 int strLen = strlen(fileName);
627 unsigned int notZeroLen = strLen > 0;
628
629 if(strLen > 0 && (fileName[strLen - 1] == '/' || fileName[strLen - 1] == '\\'))
630 strLen--;
631 if(notZeroLen)
632 fileName[strLen++] = '/';
633 fileName[strLen] = '\0';
634 if(strLen + strlen(directory) > (797) - 3)
635 return (((void *)0));
636 strcat(fileName, directory);
637 }
638 }
639 if(isURL && ch == '/')
640 strcat(fileName, "/");
641 if(isURL && ch == '?')
642 {
643 strcat(fileName, addedPath + c);
644 break;
645 }
646 }
647 if(archiveName[0])
648 sprintf(string, "<%s>%s", archiveName, fileName);
649 else
650 strcpy(string, fileName);
651 }
652 return modified ? string : (((void *)0));
653 }
654
655 char * __ecereNameSpace__ecere__sys__PathCat(char * string, char * addedPath)
656 {
657 unsigned int modified = 0x0;
658
659 if(addedPath)
660 {
661 char fileName[797] = "", archiveName[797] = "", * file;
662 int c = 0;
663 unsigned int isURL = 0x0;
664 char * urlFileName;
665
666 if(__ecereNameSpace__ecere__sys__SplitArchivePath(string, archiveName, &file))
667 strcpy(fileName, file);
668 else
669 {
670 strcpy(fileName, string);
671 }
672 if(strstr(string, "http://") == string)
673 {
674 char * slash = strstr(fileName + 7, "/");
675
676 isURL = 0x1;
677 if(slash)
678 urlFileName = slash;
679 else
680 urlFileName = fileName + strlen(fileName);
681 }
682 if(strstr(addedPath, "http://") == addedPath)
683 {
684 strcpy(fileName, "http://");
685 isURL = 0x1;
686 c = 7;
687 }
688 else if(runtimePlatform == 1)
689 {
690 if(addedPath[0] && addedPath[1] == ':' && addedPath[0] != '<')
691 {
692 fileName[0] = (char)toupper(addedPath[0]);
693 fileName[1] = ':';
694 fileName[2] = '\0';
695 c = 2;
696 modified = 0x1;
697 }
698 else if(addedPath[0] == '\\' && addedPath[1] == '\\')
699 {
700 fileName[0] = fileName[1] = '\\';
701 fileName[2] = '\0';
702 c = 2;
703 modified = 0x1;
704 }
705 else if(fileName[0] == '/' && !archiveName[0] && strcmp(addedPath, "/"))
706 return (((void *)0));
707 }
708 if(!modified && isURL && (addedPath[0] == '\\' || addedPath[0] == '/'))
709 {
710 urlFileName[0] = '/';
711 urlFileName[1] = '\0';
712 }
713 else if(!modified && (addedPath[0] == '\\' || addedPath[0] == '/'))
714 {
715 if(runtimePlatform == 1)
716 {
717 if(addedPath[0] == '/' && !addedPath[1])
718 {
719 fileName[0] = addedPath[0];
720 fileName[1] = '\0';
721 modified = 0x1;
722 }
723 else if(fileName[0] && fileName[1] == ':')
724 {
725 fileName[2] = '\0';
726 modified = 0x1;
727 }
728 else
729 {
730 fileName[0] = '\\';
731 fileName[1] = '\0';
732 modified = 0x1;
733 }
734 }
735 else
736 {
737 fileName[0] = '/';
738 fileName[1] = '\0';
739 modified = 0x1;
740 }
741 c = 1;
742 }
743 for(; addedPath[c]; )
744 {
745 char directory[4384LL];
746 int len = 0;
747 char ch;
748 int count;
749
750 for(; (ch = addedPath[c]) && (ch == '/' || ch == '\\'); c++)
751 ;
752 for(; (ch = addedPath[c]) && (ch != '/' && ch != '\\'); c++)
753 {
754 if(isURL && ch == '?')
755 {
756 break;
757 }
758 if(len < (274))
759 directory[len++] = ch;
760 }
761 directory[len] = '\0';
762 for(count = len - 1; count >= 0 && (directory[count] == ' ' || directory[count] == '\t'); count--)
763 {
764 directory[count] = '\0';
765 len--;
766 }
767 if(len > 0)
768 {
769 modified = 0x1;
770 if(strstr(directory, "..") == directory && (!directory[2] || directory[2] == ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? '\\' : '/')))
771 {
772 int strLen = strlen(fileName) - 1;
773
774 if(strLen > -1)
775 {
776 unsigned int separator = 0x0;
777
778 for(; (ch = fileName[strLen]) && strLen > -1 && (ch == '/' || ch == '\\'); strLen--)
779 ;
780 for(; (ch = fileName[strLen]) && strLen > -1 && (ch != '/' && ch != '\\' && ch != ':'); strLen--)
781 ;
782 for(; (ch = fileName[strLen]) && strLen > -1 && (ch == '/' || ch == '\\'); strLen--)
783 separator = 0x1;
784 if(isURL)
785 {
786 int __simpleStruct0;
787
788 strLen = (__simpleStruct0 = urlFileName - fileName, (strLen > __simpleStruct0) ? strLen : __simpleStruct0);
789 }
790 if(!strcmp(fileName + strLen + (separator ? 2 : 1), ".."))
791 {
792 strcat(fileName, ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? "\\" : "/"));
793 strcat(fileName, "..");
794 }
795 else
796 {
797 if(runtimePlatform == 1)
798 {
799 if(!strLen && fileName[0] == '\\' && fileName[1] == '\\')
800 {
801 if(!fileName[2])
802 return (((void *)0));
803 else
804 {
805 fileName[0] = '\\';
806 fileName[1] = '\\';
807 fileName[2] = '\0';
808 }
809 }
810 else
811 fileName[strLen + 1] = '\0';
812 }
813 else
814 {
815 fileName[strLen + 1] = '\0';
816 if(strLen < 0)
817 {
818 fileName[0] = '/';
819 fileName[1] = '\0';
820 strLen = 2;
821 }
822 }
823 }
824 }
825 else
826 {
827 strcpy(fileName, "..");
828 }
829 }
830 else if(strcmp(directory, "."))
831 {
832 int strLen = strlen(fileName);
833 unsigned int notZeroLen = strLen > 0;
834
835 if(strLen > 0 && (fileName[strLen - 1] == '/' || fileName[strLen - 1] == '\\'))
836 strLen--;
837 if(notZeroLen)
838 {
839 if(isURL)
840 fileName[strLen++] = '/';
841 else
842 fileName[strLen++] = ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? '\\' : '/');
843 }
844 fileName[strLen] = '\0';
845 if(strLen + strlen(directory) > (797) - 3)
846 return (((void *)0));
847 strcat(fileName, directory);
848 }
849 }
850 if(isURL && ch == '/')
851 strcat(fileName, "/");
852 if(isURL && ch == '?')
853 {
854 strcat(fileName, addedPath + c);
855 break;
856 }
857 }
858 if(archiveName[0])
859 sprintf(string, "<%s>%s", archiveName, fileName);
860 else
861 strcpy(string, fileName);
862 }
863 return modified ? string : (((void *)0));
864 }
865
866 extern int strcasecmp(const char * , const char * );
867
868 char * __ecereNameSpace__ecere__sys__MakePathRelative(char * path, char * to, char * destination)
869 {
870 if(!path[0])
871 memmove(destination, path, strlen(path) + 1);
872 else
873 {
874 char pathPart[4384LL], pathRest[797];
875 char toPart[4384LL], toRest[797];
876 unsigned int different = 0x0;
877
878 strcpy(pathRest, path);
879 strcpy(toRest, to);
880 destination[0] = '\0';
881 for(; toRest[0]; )
882 {
883 __ecereNameSpace__ecere__sys__SplitDirectory(toRest, toPart, toRest);
884 if(!different)
885 __ecereNameSpace__ecere__sys__SplitDirectory(pathRest, pathPart, pathRest);
886 if(different || ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? (strcasecmp) : strcmp)(toPart, pathPart))
887 {
888 different = 0x1;
889 strcat(destination, "..");
890 strcat(destination, ((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? "\\" : "/"));
891 }
892 }
893 if(different)
894 __ecereNameSpace__ecere__sys__PathCat(destination, pathPart);
895 for(; pathRest[0]; )
896 {
897 __ecereNameSpace__ecere__sys__SplitDirectory(pathRest, pathPart, pathRest);
898 __ecereNameSpace__ecere__sys__PathCat(destination, pathPart);
899 }
900 }
901 return destination;
902 }
903
904 unsigned int __ecereNameSpace__ecere__sys__StripExtension(char * string)
905 {
906 int c;
907
908 for(c = strlen(string); c >= 0; c--)
909 if(string[c] == '.')
910 {
911 string[c] = '\0';
912 return 0x1;
913 }
914 else if(string[c] == '\\' || string[c] == '/')
915 break;
916 return 0x0;
917 }
918
919 char * __ecereNameSpace__ecere__sys__ChangeExtension(char * string, char * ext, char * output)
920 {
921 if(string != output)
922 strcpy(output, string);
923 __ecereNameSpace__ecere__sys__StripExtension(output);
924 if(ext[0])
925 strcat(output, ".");
926 strcat(output, ext);
927 return output;
928 }
929
930 void __ecereNameSpace__ecere__sys__PrintSize(char * string, unsigned int size, int prec)
931 {
932 if(size > 1024)
933 {
934 char format[8];
935
936 sprintf(format, "%%.0%df", prec);
937 if(size > 1024 * 1024 * 1024)
938 {
939 sprintf(string, format, (float)size / (float)((float)(float)(1024 * 1024 * 1024)));
940 strcat(string, " GB");
941 }
942 else if(size > 1024 * 1024)
943 {
944 sprintf(string, format, (float)size / (float)((float)(float)(1024 * 1024)));
945 strcat(string, " MB");
946 }
947 else
948 {
949 sprintf(string, format, (float)size / (float)(float)1024);
950 strcat(string, " KB");
951 }
952 }
953 else
954 sprintf(string, "%d B", size);
955 }
956
957 void __ecereNameSpace__ecere__sys__PrintBigSize(char * string, double size, int prec)
958 {
959 if(size > (double)1024)
960 {
961 char format[8];
962
963 sprintf(format, "%%.0%df", prec);
964 if(size > 1024.0 * 1024.0 * 1024.0 * 1024.0)
965 {
966 sprintf(string, format, size / ((double)(double)(1024 * 1024) * 1024.0 * 1024.0));
967 strcat(string, " TB");
968 }
969 else if(size > 1024.0 * 1024.0 * 1024.0)
970 {
971 sprintf(string, format, size / (1024.0 * 1024.0 * 1024.0));
972 strcat(string, " GB");
973 }
974 else if(size > 1024.0 * 1024.0)
975 {
976 sprintf(string, format, size / (1024.0 * 1024.0));
977 strcat(string, " MB");
978 }
979 else
980 {
981 sprintf(string, format, size / 1024.0);
982 strcat(string, " KB");
983 }
984 }
985 else
986 sprintf(string, "%.0f B", size);
987 }
988
989 extern int strncmp(const char * , const char * , int n);
990
991 extern int strncasecmp(const char * , const char * , int n);
992
993 extern int tolower(int);
994
995 extern int isalnum(int c);
996
997 char * __ecereNameSpace__ecere__sys__SearchString(char * buffer, int start, char * subStr, unsigned int matchCase, unsigned int matchWord)
998 {
999 if(buffer && subStr)
1000 {
1001 char * ptr;
1002 char * strBuffer = buffer + start;
1003 int subLen = strlen(subStr);
1004 char beforeChar = start ? *(strBuffer - 1) : (char)0;
1005 int (* strcompare)(const char *, const char *, unsigned int) = matchCase ? strncmp : (strncasecmp);
1006
1007 for(ptr = strBuffer; *ptr; ptr++)
1008 {
1009 if(matchCase ? (*subStr == *ptr) : (tolower(*subStr) == tolower(*ptr)))
1010 {
1011 if(matchWord)
1012 {
1013 if(!strcompare(ptr, subStr, subLen) && (!((subStr[subLen - 1]) == '_' || isalnum((subStr[subLen - 1]))) || !((ptr[subLen]) == '_' || isalnum((ptr[subLen])))) && (!((subStr[0]) == '_' || isalnum((subStr[0]))) || !((beforeChar) == '_' || isalnum((beforeChar)))))
1014 return ptr;
1015 }
1016 else
1017 {
1018 if(!strcompare(ptr, subStr, subLen))
1019 return ptr;
1020 }
1021 }
1022 beforeChar = ptr[0];
1023 }
1024 }
1025 return (((void *)0));
1026 }
1027
1028 char * __ecereNameSpace__ecere__sys__RSearchString(char * buffer, char * subStr, int maxLen, unsigned int matchCase, unsigned int matchWord)
1029 {
1030 if(buffer && subStr)
1031 {
1032 int subLen = strlen(subStr);
1033 char * ptr1 = buffer + maxLen - subLen;
1034 char * ptr2 = buffer + maxLen - subLen - 1;
1035 int (* strcompare)(const char *, const char *, unsigned int) = matchCase ? strncmp : (strncasecmp);
1036
1037 for(; ptr1 >= buffer; ptr1--, ptr2--)
1038 {
1039 if(tolower(*subStr) == tolower(*ptr1))
1040 {
1041 if(matchWord)
1042 {
1043 if(!strcompare(ptr1, subStr, subLen) && (!((subStr[subLen - 1]) == '_' || isalnum((subStr[subLen - 1]))) || !((ptr1[subLen]) == '_' || isalnum((ptr1[subLen])))) && (!((subStr[0]) == '_' || isalnum((subStr[0]))) || !((*ptr2) == '_' || isalnum((*ptr2)))))
1044 return ptr1;
1045 }
1046 else
1047 {
1048 if(!strcompare(ptr1, subStr, subLen))
1049 return ptr1;
1050 }
1051 }
1052 }
1053 }
1054 return (((void *)0));
1055 }
1056
1057 int __ecereNameSpace__ecere__sys__Tokenize(char * string, int maxTokens, char * tokens[], unsigned int escapeBackSlashes)
1058 {
1059 int count = 0;
1060 unsigned int quoted = 0x0;
1061 unsigned char * start = (((void *)0));
1062 unsigned int escaped = 0x0;
1063 char * output = string;
1064
1065 for(; *string && count < maxTokens; string++, output++)
1066 {
1067 if(output != string)
1068 *output = *string;
1069 if(start)
1070 {
1071 if(escaped)
1072 {
1073 escaped = 0x0;
1074 output--;
1075 if(output != string)
1076 *output = *string;
1077 }
1078 else if(escapeBackSlashes && *string == '\\')
1079 escaped = 0x1;
1080 else if(*string == '\"')
1081 {
1082 if(quoted)
1083 {
1084 *output = '\0';
1085 quoted = 0x0;
1086 }
1087 else
1088 {
1089 memmove(start + 1, start, string - (char *)start);
1090 start++;
1091 }
1092 }
1093 else if(*string == ' ' && !quoted)
1094 {
1095 tokens[count++] = start;
1096 *output = '\0';
1097 start = (((void *)0));
1098 }
1099 }
1100 else if(*string != ' ')
1101 {
1102 if(*string == '\"')
1103 {
1104 quoted = 0x1;
1105 start = output + 1;
1106 }
1107 else
1108 {
1109 start = output;
1110 if(*string == '\\' && escapeBackSlashes)
1111 escaped = 0x1;
1112 }
1113 }
1114 }
1115 if(start && count < maxTokens)
1116 {
1117 tokens[count++] = start;
1118 *output = '\0';
1119 }
1120 return count;
1121 }
1122
1123 extern char *  strchr(char * , int);
1124
1125 int __ecereNameSpace__ecere__sys__TokenizeWith(char * string, int maxTokens, char * tokens[], char * tokenizers, unsigned int escapeBackSlashes)
1126 {
1127 int count = 0;
1128 unsigned int quoted = 0x0;
1129 unsigned char * start = (((void *)0));
1130 unsigned int escaped = 0x0;
1131 char * output = string;
1132 unsigned int quotedFromStart = 0x0;
1133
1134 for(; *string && count < maxTokens; string++, output++)
1135 {
1136 if(output != string)
1137 *output = *string;
1138 if(start)
1139 {
1140 if(escaped)
1141 {
1142 escaped = 0x0;
1143 output--;
1144 if(output != string)
1145 *output = *string;
1146 }
1147 else if(escapeBackSlashes && *string == '\\')
1148 escaped = 0x1;
1149 else if(*string == '\"')
1150 {
1151 if(quoted)
1152 {
1153 if(quotedFromStart)
1154 *output = '\0';
1155 quotedFromStart = 0x0;
1156 quoted = 0x0;
1157 }
1158 else
1159 quoted = 0x1;
1160 }
1161 else if(strchr(tokenizers, *string) && !quoted)
1162 {
1163 tokens[count++] = start;
1164 *output = '\0';
1165 start = (((void *)0));
1166 }
1167 }
1168 else if(!strchr(tokenizers, *string))
1169 {
1170 if(*string == '\"')
1171 {
1172 quotedFromStart = 0x1;
1173 quoted = 0x1;
1174 start = output + 1;
1175 }
1176 else
1177 {
1178 start = output;
1179 if(*string == '\\' && escapeBackSlashes)
1180 escaped = 0x1;
1181 }
1182 }
1183 }
1184 if(start && count < maxTokens)
1185 {
1186 tokens[count++] = start;
1187 *output = '\0';
1188 }
1189 return count;
1190 }
1191
1192 char * __ecereNameSpace__ecere__sys__TrimLSpaces(char * string, char * output)
1193 {
1194 int c;
1195
1196 for(c = 0; string[c] && string[c] == ' '; c++)
1197 ;
1198 memmove(output, string + c, strlen(string + c) + 1);
1199 return output;
1200 }
1201
1202 char * __ecereNameSpace__ecere__sys__TrimRSpaces(char * string, char * output)
1203 {
1204 int c;
1205
1206 for(c = strlen(string) - 1; c >= 0 && string[c] == ' '; c--)
1207 ;
1208 if(c >= 0)
1209 {
1210 memmove(output, string, c + 1);
1211 output[c + 1] = '\0';
1212 }
1213 else
1214 output[0] = '\0';
1215 return output;
1216 }
1217
1218 void __ecereNameSpace__ecere__sys__ChangeCh(char * string, char ch1, char ch2)
1219 {
1220 int c;
1221
1222 for(c = 0; string[c]; c++)
1223 if(string[c] == ch1)
1224 string[c] = ch2;
1225 }
1226
1227 void __ecereNameSpace__ecere__sys__RepeatCh(char * string, int count, char ch)
1228 {
1229 int c;
1230
1231 for(c = 0; c < count; c++)
1232 string[c] = ch;
1233 string[c] = (char)0;
1234 }
1235
1236 extern void *  memcpy(void * , const void * , unsigned int size);
1237
1238 char * __ecereNameSpace__ecere__sys__CopyString(char * string)
1239 {
1240 if(string)
1241 {
1242 int len = strlen(string);
1243 char * destination = __ecereNameSpace__ecere__com__eSystem_New(sizeof(char) * (len + 1));
1244
1245 if(destination)
1246 memcpy(destination, string, len + 1);
1247 return destination;
1248 }
1249 else
1250 return (((void *)0));
1251 }
1252
1253 unsigned int __ecereNameSpace__ecere__sys__GetString(char ** buffer, char * string, int max)
1254 {
1255 int c;
1256 char ch;
1257 unsigned int quoted = 0x0;
1258 unsigned int result = 0x1;
1259
1260 if(!* *buffer)
1261 {
1262 string[0] = (char)0;
1263 return 0x0;
1264 }
1265 for(; ; )
1266 {
1267 if(!(ch = *((*buffer)++)))
1268 result = 0x0;
1269 if((ch != '\n') && (ch != '\r') && (ch != ' ') && (ch != ',') && (ch != '\t'))
1270 break;
1271 if(!*(*buffer))
1272 break;
1273 }
1274 if(result)
1275 {
1276 for(c = 0; c < max - 1; c++)
1277 {
1278 if(!quoted && ((ch == '\n') || (ch == '\r') || (ch == ' ') || (ch == ',') || (ch == '\t')))
1279 {
1280 result = 0x1;
1281 break;
1282 }
1283 if(ch == '\"')
1284 {
1285 quoted ^= (unsigned int)1;
1286 c--;
1287 }
1288 else
1289 string[c] = ch;
1290 if(!(ch = *(*buffer)))
1291 {
1292 c++;
1293 break;
1294 }
1295 (*buffer)++;
1296 }
1297 string[c] = (char)0;
1298 }
1299 return result;
1300 }
1301
1302 extern int atoi(const char * );
1303
1304 int __ecereNameSpace__ecere__sys__GetValue(char ** buffer)
1305 {
1306 char string[20];
1307
1308 __ecereNameSpace__ecere__sys__GetString(buffer, string, 20);
1309 return atoi(string);
1310 }
1311
1312 extern unsigned long strtoul(const char *  nptr, char * *  endptr, int base);
1313
1314 unsigned int __ecereNameSpace__ecere__sys__GetHexValue(char ** buffer)
1315 {
1316 char string[20];
1317
1318 __ecereNameSpace__ecere__sys__GetString(buffer, string, 20);
1319 return strtoul(string, (((void *)0)), 16);
1320 }
1321
1322 char * __ecereNameSpace__ecere__sys__StripQuotes(char * string, char * output)
1323 {
1324 int len;
1325 char * src = (string[0] == '\"') ? (string + 1) : string;
1326
1327 memmove(output, src, strlen(src) + 1);
1328 len = strlen(output);
1329 if(len && output[len - 1] == '\"')
1330 output[len - 1] = '\0';
1331 return output;
1332 }
1333
1334 extern unsigned int isdigit(int);
1335
1336 double __ecereNameSpace__ecere__sys__FloatFromString(char * string)
1337 {
1338 int c, dig;
1339 float dec = (float)0, res = (float)0;
1340 int neg = 1;
1341 char ch;
1342
1343 for(c = 0; string[c]; c++)
1344 {
1345 ch = string[c];
1346 if(ch == ' ')
1347 continue;
1348 if(ch == '-')
1349 {
1350 if(neg == -1)
1351 break;
1352 neg = -1;
1353 }
1354 else if((ch == '.') && !dec)
1355 dec = (float)10;
1356 else if(isdigit(ch))
1357 {
1358 dig = ch - '0';
1359 if(dec)
1360 {
1361 res += (float)dig / dec;
1362 dec *= 10;
1363 }
1364 else
1365 res = res * (float)10 + (float)dig;
1366 }
1367 else
1368 break;
1369 }
1370 return (float)neg * res;
1371 }
1372
1373 unsigned int __ecereNameSpace__ecere__sys__IsPathInsideOf(char * path, char * of)
1374 {
1375 if(!path[0] || !of[0])
1376 return 0x0;
1377 else
1378 {
1379 char ofPart[274], ofRest[797];
1380 char pathPart[274], pathRest[797];
1381
1382 strcpy(ofRest, of);
1383 strcpy(pathRest, path);
1384 for(; ofRest[0] && pathRest[0]; )
1385 {
1386 __ecereNameSpace__ecere__sys__SplitDirectory(ofRest, ofPart, ofRest);
1387 __ecereNameSpace__ecere__sys__SplitDirectory(pathRest, pathPart, pathRest);
1388 if(((__ecereNameSpace__ecere__com__GetRuntimePlatform() == 1) ? (strcasecmp) : strcmp)(pathPart, ofPart))
1389 return 0x0;
1390 }
1391 if(!ofRest[0] && !pathRest[0])
1392 return 0x0;
1393 else if(!pathRest[0])
1394 return 0x0;
1395 return 0x1;
1396 }
1397 }
1398
1399 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DefinedExpression;
1400
1401 struct __ecereNameSpace__ecere__com__DefinedExpression;
1402
1403 extern struct __ecereNameSpace__ecere__com__DefinedExpression * __ecereNameSpace__ecere__com__eSystem_RegisterDefine(char *  name, char *  value, struct __ecereNameSpace__ecere__com__Instance * module, int declMode);
1404
1405 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__GlobalFunction;
1406
1407 struct __ecereNameSpace__ecere__com__GlobalFunction;
1408
1409 extern struct __ecereNameSpace__ecere__com__GlobalFunction * __ecereNameSpace__ecere__com__eSystem_RegisterFunction(char *  name, char *  type, void *  func, struct __ecereNameSpace__ecere__com__Instance * module, int declMode);
1410
1411 void __ecereRegisterModule_String(struct __ecereNameSpace__ecere__com__Instance * module)
1412 {
1413 struct __ecereNameSpace__ecere__com__Class * class;
1414
1415 __ecereNameSpace__ecere__com__eSystem_RegisterDefine("ecere::sys::DIR_SEP", "(GetRuntimePlatform() == win32) ? '\\\\' : '/'", module, 4);
1416 __ecereNameSpace__ecere__com__eSystem_RegisterDefine("ecere::sys::DIR_SEPS", "(GetRuntimePlatform() == win32) ? \"\\\\\" : \"/\"", module, 4);
1417 __ecereNameSpace__ecere__com__eSystem_RegisterDefine("ecere::sys::MAX_F_STRING", "1025", module, 4);
1418 __ecereNameSpace__ecere__com__eSystem_RegisterDefine("ecere::sys::MAX_EXTENSION", "17", module, 4);
1419 __ecereNameSpace__ecere__com__eSystem_RegisterDefine("ecere::sys::MAX_FILENAME", "274", module, 4);
1420 __ecereNameSpace__ecere__com__eSystem_RegisterDefine("ecere::sys::MAX_DIRECTORY", "534", module, 4);
1421 __ecereNameSpace__ecere__com__eSystem_RegisterDefine("ecere::sys::MAX_LOCATION", "797", module, 4);
1422 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::GetExtension", "char * ecere::sys::GetExtension(char * string, char * output)", __ecereNameSpace__ecere__sys__GetExtension, module, 4);
1423 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::StripLastDirectory", "char * ecere::sys::StripLastDirectory(char * string, char * output)", __ecereNameSpace__ecere__sys__StripLastDirectory, module, 4);
1424 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::SplitDirectory", "char * ecere::sys::SplitDirectory(char * string, char * part, char * rest)", __ecereNameSpace__ecere__sys__SplitDirectory, module, 4);
1425 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::GetLastDirectory", "char * ecere::sys::GetLastDirectory(char * string, char * output)", __ecereNameSpace__ecere__sys__GetLastDirectory, module, 4);
1426 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::SplitArchivePath", "bool ecere::sys::SplitArchivePath(char * fileName, char * archiveName, char * * archiveFile)", __ecereNameSpace__ecere__sys__SplitArchivePath, module, 4);
1427 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::PathCatSlash", "char * ecere::sys::PathCatSlash(char * string, char * addedPath)", __ecereNameSpace__ecere__sys__PathCatSlash, module, 4);
1428 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::PathCat", "char * ecere::sys::PathCat(char * string, char * addedPath)", __ecereNameSpace__ecere__sys__PathCat, module, 4);
1429 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::MakePathRelative", "char * ecere::sys::MakePathRelative(char * path, char * to, char * destination)", __ecereNameSpace__ecere__sys__MakePathRelative, module, 4);
1430 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::StripExtension", "bool ecere::sys::StripExtension(char * string)", __ecereNameSpace__ecere__sys__StripExtension, module, 4);
1431 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::ChangeExtension", "char * ecere::sys::ChangeExtension(char * string, char * ext, char * output)", __ecereNameSpace__ecere__sys__ChangeExtension, module, 4);
1432 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::PrintSize", "void ecere::sys::PrintSize(char * string, uint size, int prec)", __ecereNameSpace__ecere__sys__PrintSize, module, 4);
1433 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::PrintBigSize", "void ecere::sys::PrintBigSize(char * string, double size, int prec)", __ecereNameSpace__ecere__sys__PrintBigSize, module, 4);
1434 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::SearchString", "char * ecere::sys::SearchString(char * buffer, int start, char * subStr, bool matchCase, bool matchWord)", __ecereNameSpace__ecere__sys__SearchString, module, 4);
1435 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::RSearchString", "char * ecere::sys::RSearchString(char * buffer, char * subStr, int maxLen, bool matchCase, bool matchWord)", __ecereNameSpace__ecere__sys__RSearchString, module, 4);
1436 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::Tokenize", "int ecere::sys::Tokenize(char * string, int maxTokens, char * tokens[], bool escapeBackSlashes)", __ecereNameSpace__ecere__sys__Tokenize, module, 4);
1437 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::TokenizeWith", "int ecere::sys::TokenizeWith(char * string, int maxTokens, char * tokens[], char * tokenizers, bool escapeBackSlashes)", __ecereNameSpace__ecere__sys__TokenizeWith, module, 4);
1438 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::TrimLSpaces", "char * ecere::sys::TrimLSpaces(char * string, char * output)", __ecereNameSpace__ecere__sys__TrimLSpaces, module, 4);
1439 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::TrimRSpaces", "char * ecere::sys::TrimRSpaces(char * string, char * output)", __ecereNameSpace__ecere__sys__TrimRSpaces, module, 4);
1440 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::ChangeCh", "void ecere::sys::ChangeCh(char * string, char ch1, char ch2)", __ecereNameSpace__ecere__sys__ChangeCh, module, 4);
1441 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::RepeatCh", "void ecere::sys::RepeatCh(char * string, int count, char ch)", __ecereNameSpace__ecere__sys__RepeatCh, module, 4);
1442 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::CopyString", "char * ecere::sys::CopyString(char * string)", __ecereNameSpace__ecere__sys__CopyString, module, 4);
1443 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::GetString", "bool ecere::sys::GetString(char * * buffer, char * string, int max)", __ecereNameSpace__ecere__sys__GetString, module, 4);
1444 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::GetValue", "int ecere::sys::GetValue(char * * buffer)", __ecereNameSpace__ecere__sys__GetValue, module, 4);
1445 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::GetHexValue", "uint ecere::sys::GetHexValue(char * * buffer)", __ecereNameSpace__ecere__sys__GetHexValue, module, 4);
1446 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::StripQuotes", "char * ecere::sys::StripQuotes(char * string, char * output)", __ecereNameSpace__ecere__sys__StripQuotes, module, 4);
1447 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::FloatFromString", "double ecere::sys::FloatFromString(char * string)", __ecereNameSpace__ecere__sys__FloatFromString, module, 4);
1448 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::IsPathInsideOf", "bool ecere::sys::IsPathInsideOf(char * path, char * of)", __ecereNameSpace__ecere__sys__IsPathInsideOf, module, 4);
1449 }
1450
1451 void __ecereUnregisterModule_String(struct __ecereNameSpace__ecere__com__Instance * module)
1452 {
1453
1454 }
1455