util/OptionParser: use ConstBuffer<const char*> to store argv/argc

This commit is contained in:
Max Kellermann 2018-01-16 10:11:06 +01:00
parent 4a304bf34e
commit 23dff4f209
2 changed files with 6 additions and 7 deletions

View File

@ -40,9 +40,7 @@ bool
OptionParser::ParseNext() noexcept
{
assert(HasEntries());
const char *arg = *argv;
++argv;
--argc;
const char *arg = args.shift();
if (arg[0] == '-') {
if (arg[1] == '-') {
option = arg + 2;

View File

@ -20,6 +20,8 @@
#ifndef MPD_UTIL_OPTIONPARSER_HXX
#define MPD_UTIL_OPTIONPARSER_HXX
#include "util/ConstBuffer.hxx"
#include <assert.h>
class OptionDef;
@ -29,8 +31,7 @@ class OptionDef;
*/
class OptionParser
{
int argc;
char *const*argv;
ConstBuffer<const char *> args;
const char *option = nullptr;
const char *option_raw = nullptr;
bool is_long = false;
@ -40,13 +41,13 @@ public:
* Constructs #OptionParser.
*/
constexpr OptionParser(int _argc, char *const*_argv) noexcept
:argc(_argc - 1), argv(_argv + 1) {}
:args(_argv + 1, _argc - 1) {}
/**
* Checks if there are command line entries to process.
*/
constexpr bool HasEntries() const noexcept {
return argc > 0;
return !args.empty();
}
/**