1
0
mirror of git://projects.qi-hardware.com/openwrt-xburst.git synced 2024-11-24 03:30:37 +02:00

[package] nvram: fix crash when get, set or unset is invoked without argument (#7263)

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@21288 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
jow 2010-05-02 00:45:03 +00:00
parent ec79a3d916
commit a1dcc39e13
2 changed files with 26 additions and 14 deletions

View File

@ -8,7 +8,7 @@
include $(TOPDIR)/rules.mk include $(TOPDIR)/rules.mk
PKG_NAME:=nvram PKG_NAME:=nvram
PKG_RELEASE:=5 PKG_RELEASE:=6
PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_NAME) PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_NAME)

View File

@ -165,20 +165,32 @@ int main( int argc, const char *argv[] )
stat = do_info(nvram); stat = do_info(nvram);
done++; done++;
} }
else if( !strcmp(argv[i], "get") && ++i < argc ) else if( !strcmp(argv[i], "get") || !strcmp(argv[i], "unset") || !strcmp(argv[i], "set") )
{ {
if( (i+1) < argc )
{
switch(argv[i++][0])
{
case 'g':
stat = do_get(nvram, argv[i]); stat = do_get(nvram, argv[i]);
done++; break;
}
else if( !strcmp(argv[i], "unset") && ++i < argc ) case 'u':
{
stat = do_unset(nvram, argv[i]); stat = do_unset(nvram, argv[i]);
break;
case 's':
stat = do_set(nvram, argv[i]);
break;
}
done++; done++;
} }
else if( !strcmp(argv[i], "set") && ++i < argc ) else
{ {
stat = do_set(nvram, argv[i]); fprintf(stderr, "Command '%s' requires an argument!\n", argv[i]);
done++; done = 0;
break;
}
} }
else if( !strcmp(argv[i], "commit") ) else if( !strcmp(argv[i], "commit") )
{ {