OptionParser.cpp
2.36 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
//===-- source/Host/common/OptionParser.cpp ---------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "lldb/Host/OptionParser.h"
#include "lldb/Host/HostGetOpt.h"
#include "lldb/lldb-private-types.h"
#include <vector>
using namespace lldb_private;
void OptionParser::Prepare(std::unique_lock<std::mutex> &lock) {
static std::mutex g_mutex;
lock = std::unique_lock<std::mutex>(g_mutex);
#ifdef __GLIBC__
optind = 0;
#else
optreset = 1;
optind = 1;
#endif
}
void OptionParser::EnableError(bool error) { opterr = error ? 1 : 0; }
int OptionParser::Parse(llvm::MutableArrayRef<char *> argv,
llvm::StringRef optstring, const Option *longopts,
int *longindex) {
std::vector<option> opts;
while (longopts->definition != nullptr) {
option opt;
opt.flag = longopts->flag;
opt.val = longopts->val;
opt.name = longopts->definition->long_option;
opt.has_arg = longopts->definition->option_has_arg;
opts.push_back(opt);
++longopts;
}
opts.push_back(option());
std::string opt_cstr = optstring;
return getopt_long_only(argv.size() - 1, argv.data(), opt_cstr.c_str(),
&opts[0], longindex);
}
char *OptionParser::GetOptionArgument() { return optarg; }
int OptionParser::GetOptionIndex() { return optind; }
int OptionParser::GetOptionErrorCause() { return optopt; }
std::string OptionParser::GetShortOptionString(struct option *long_options) {
std::string s;
int i = 0;
bool done = false;
while (!done) {
if (long_options[i].name == nullptr && long_options[i].has_arg == 0 &&
long_options[i].flag == nullptr && long_options[i].val == 0) {
done = true;
} else {
if (long_options[i].flag == nullptr && isalpha(long_options[i].val)) {
s.append(1, (char)long_options[i].val);
switch (long_options[i].has_arg) {
default:
case no_argument:
break;
case optional_argument:
s.append(2, ':');
break;
case required_argument:
s.append(1, ':');
break;
}
}
++i;
}
}
return s;
}