hedgewars/ArgParsers.pas
changeset 10173 fff5e4b0dfcb
parent 10108 c68cf030eded
child 10175 c92668840ea8
--- a/hedgewars/ArgParsers.pas	Sat Mar 01 15:04:38 2014 -0500
+++ b/hedgewars/ArgParsers.pas	Sun Mar 02 00:34:18 2014 +0400
@@ -25,6 +25,10 @@
 procedure GetParams;
 {$ELSE}
 procedure parseCommandLine(argc: LongInt; argv: PPChar);
+
+var operatingsystem_parameter_argc: integer = 0; export;
+    operatingsystem_parameter_argv: pointer = nil; export;
+    operatingsystem_parameter_envp: pointer = nil; export;
 {$ENDIF}
 
 implementation
@@ -146,6 +150,7 @@
     // Silence the hint that appears when USE_VIDEO_RECORDING is not defined
     paramIndex:= paramIndex;
 {$IFDEF USE_VIDEO_RECORDING}
+{$IFNDEF HWLIBRARY}
     GameType:= gmtRecord;
     inc(paramIndex);
     cVideoFramerateNum:= StrToInt(ParamStr(paramIndex)); inc(paramIndex);
@@ -156,13 +161,14 @@
     cVideoQuality:= StrToInt(ParamStr(paramIndex));      inc(paramIndex);
     cAudioCodec:= ParamStr(paramIndex);                  inc(paramIndex);
 {$ENDIF}
+{$ENDIF}
 end;
 
 function getLongIntParameter(str:shortstring; var paramIndex:LongInt; var wrongParameter:Boolean): LongInt;
 var tmpInt, c: LongInt;
 begin
     inc(paramIndex);
-{$IFDEF PAS2C}
+{$IFDEF PAS2C OR HWLIBRARY}
     val(str, tmpInt);
 {$ELSE}
     val(str, tmpInt, c);
@@ -177,8 +183,10 @@
 begin
     inc(paramIndex);
     wrongParameter:= (str='') or (Copy(str,1,2) = '--');
+    {$IFNDEF HWLIBRARY}
     if wrongParameter then
-         WriteLn(stderr, 'ERROR: '+ParamStr(paramIndex-1)+' expects a string, you passed "'+str+'"');
+        WriteLn(stderr, 'ERROR: '+ParamStr(paramIndex-1)+' expects a string, you passed "'+str+'"');
+    {$ENDIF}
     getstringParameter:= str;
 end;
 
@@ -277,7 +285,7 @@
         newSyntax:= '';
         inc(paramIndex);
         cmd:= cmdarray[index];
-        arg:= ParamStr(paramIndex);
+        arg:= cmdarray[paramIndex];
         isValid:= (cmd<>'--depth');
 
         // check if the parameter is a boolean one
@@ -309,6 +317,11 @@
     wrongParameter: boolean;
 //var tmpInt: LongInt;
 begin
+    {$IFDEF HWLIBRARY}
+    operatingsystem_parameter_argc:= argc;
+    operatingsystem_parameter_argv:= argv;
+    {$ENDIF}
+
     paramIndex:= {$IFDEF HWLIBRARY}0{$ELSE}1{$ENDIF};
     paramTotal:= {$IFDEF HWLIBRARY}argc-1{$ELSE}ParamCount{$ENDIF}; //-1 because pascal enumeration is inclusive
     (*