Pad arguments for commands
FossilOrigin-Name: 852e3a48c314a7a6eb6e5c9894e439a4be10e4fc09164981c7ba27fededc84eb
This commit is contained in:
parent
a06c4638a3
commit
f0b20e15d8
2 changed files with 56 additions and 13 deletions
|
@ -2,6 +2,22 @@
|
|||
|
||||
#include <cube.h>
|
||||
|
||||
static OFArray<OFString *> *
|
||||
padArguments(OFArray<OFString *> *arguments, size_t count)
|
||||
{
|
||||
OFMutableArray<OFString *> *copy;
|
||||
|
||||
if (arguments.count >= count)
|
||||
return arguments;
|
||||
|
||||
copy = [arguments mutableCopy];
|
||||
while (copy.count < count)
|
||||
[copy addObject:@""];
|
||||
|
||||
[copy makeImmutable];
|
||||
return copy;
|
||||
}
|
||||
|
||||
@implementation Command
|
||||
- (instancetype)initWithName:(OFString *)name
|
||||
function:(void (*)())function
|
||||
|
@ -19,83 +35,108 @@
|
|||
{
|
||||
switch (_argumentsTypes) {
|
||||
case ARG_1INT:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 2);
|
||||
((void(__cdecl *)(int))_function)(
|
||||
(int)[arguments[1] longLongValueWithBase:0]);
|
||||
}
|
||||
break;
|
||||
case ARG_2INT:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 3);
|
||||
((void(__cdecl *)(int, int))_function)(
|
||||
(int)[arguments[1] longLongValueWithBase:0],
|
||||
(int)[arguments[2] longLongValueWithBase:0]);
|
||||
}
|
||||
break;
|
||||
case ARG_3INT:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 4);
|
||||
((void(__cdecl *)(int, int, int))_function)(
|
||||
(int)[arguments[1] longLongValueWithBase:0],
|
||||
(int)[arguments[2] longLongValueWithBase:0],
|
||||
(int)[arguments[3] longLongValueWithBase:0]);
|
||||
}
|
||||
break;
|
||||
case ARG_4INT:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 5);
|
||||
((void(__cdecl *)(int, int, int, int))_function)(
|
||||
(int)[arguments[1] longLongValueWithBase:0],
|
||||
(int)[arguments[2] longLongValueWithBase:0],
|
||||
(int)[arguments[3] longLongValueWithBase:0],
|
||||
(int)[arguments[4] longLongValueWithBase:0]);
|
||||
}
|
||||
break;
|
||||
case ARG_NONE:
|
||||
if (isDown)
|
||||
((void(__cdecl *)())_function)();
|
||||
break;
|
||||
case ARG_1STR:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 2);
|
||||
((void(__cdecl *)(OFString *))_function)(arguments[1]);
|
||||
}
|
||||
break;
|
||||
case ARG_2STR:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 3);
|
||||
((void(__cdecl *)(OFString *, OFString *))_function)(
|
||||
arguments[1], arguments[2]);
|
||||
}
|
||||
break;
|
||||
case ARG_3STR:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 4);
|
||||
((void(__cdecl *)(
|
||||
OFString *, OFString *, OFString *))_function)(
|
||||
arguments[1], arguments[2], arguments[3]);
|
||||
}
|
||||
break;
|
||||
case ARG_5STR:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 6);
|
||||
((void(__cdecl *)(OFString *, OFString *, OFString *,
|
||||
OFString *, OFString *))_function)(arguments[1],
|
||||
arguments[2], arguments[3], arguments[4],
|
||||
arguments[5]);
|
||||
}
|
||||
break;
|
||||
case ARG_DOWN:
|
||||
((void(__cdecl *)(bool))_function)(isDown);
|
||||
break;
|
||||
case ARG_DWN1:
|
||||
arguments = padArguments(arguments, 2);
|
||||
((void(__cdecl *)(bool, OFString *))_function)(
|
||||
isDown, arguments[1]);
|
||||
break;
|
||||
case ARG_1EXP:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 2);
|
||||
return ((int(__cdecl *)(int))_function)(
|
||||
execute(arguments[1]));
|
||||
}
|
||||
break;
|
||||
case ARG_2EXP:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 3);
|
||||
return ((int(__cdecl *)(int, int))_function)(
|
||||
execute(arguments[1]), execute(arguments[2]));
|
||||
}
|
||||
break;
|
||||
case ARG_1EST:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 2);
|
||||
return ((int(__cdecl *)(OFString *))_function)(
|
||||
arguments[1]);
|
||||
}
|
||||
break;
|
||||
case ARG_2EST:
|
||||
if (isDown)
|
||||
if (isDown) {
|
||||
arguments = padArguments(arguments, 3);
|
||||
return ((int(__cdecl *)(OFString *,
|
||||
OFString *))_function)(arguments[1], arguments[2]);
|
||||
}
|
||||
break;
|
||||
case ARG_VARI:
|
||||
if (isDown)
|
||||
|
|
|
@ -345,12 +345,14 @@ bool
|
|||
execfile(OFString *cfgfile)
|
||||
{
|
||||
@autoreleasepool {
|
||||
OFString *command;
|
||||
@try {
|
||||
execute([OFString stringWithContentsOfFile:cfgfile]);
|
||||
command = [OFString stringWithContentsOfFile:cfgfile];
|
||||
} @catch (id e) {
|
||||
return false;
|
||||
}
|
||||
|
||||
execute(command);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue