int main(int argc, char* argv[])
{
- DWORD flags = 0;
bool pkgMode = false;
bool dllMode = false;
bool rmPkgMode = false;
return -1;
}
- // Parse optional switches first.
- if (cmdOptionExists(argv, argv+argc, "--r2r")) {
- flags |= NI_FLAGS_ENABLER2R;
- }
- if (cmdOptionExists(argv, argv+argc, "--compatibility")) {
- flags |= NI_FLAGS_COMPATIBILITY;
- }
- if (cmdOptionExists(argv, argv+argc, "--instrument")) {
- flags |= NI_FLAGS_INSTRUMENT;
+ NIOption* opt = getNIOption();
+ if (opt == nullptr) {
+ _SERR("Fail to create option structure.");
+ return -1;
}
+
+ // Parse optional switches first.
if (cmdOptionExists(argv, argv+argc, "--verbose")) {
- flags |= NI_FLAGS_VERBOSE;
+ opt->flags |= NI_FLAGS_VERBOSE;
}
// The following commands are mutually exclusive.
help(argv[0]);
return 0;
} else if (cmdOptionExists(argv, argv+argc, "--system")) {
- createNIPlatform(flags);
+ createNIPlatform("", opt->flags);
return 0;
} else if (cmdOptionExists(argv, argv+argc, "--dll")) {
dllMode = true;
} else if (cmdOptionExists(argv, argv+argc, "--reset-pkg")) {
rmPkgMode = true;
} else if (cmdOptionExists(argv, argv+argc, "--regen-all-app")) {
- regenerateAppNI(flags);
+ regenerateAppNI(opt->flags);
return 0;
} else {
help(argv[0]);
if (pkgMode) {
for (const std::string pkg : args) {
// if there is AOTed dlls under package root, that is skiped.
- int ret = createNIUnderPkgRoot(pkg, flags);
+ int ret = createNIUnderPkgRoot(pkg, opt->flags);
if (ret == NI_ERROR_INVALID_PACKAGE) {
_SERR("Failed to get root path from [%s]", pkg.c_str());
return -1;
// donot return error code for generation failure.
// we have to run crossgen for all input dlls.
for (const std::string dll : args) {
- int ret = createNIDll(dll, flags);
+ int ret = createNIDll(dll, opt->flags);
if (ret == NI_ERROR_ALREADY_EXIST) {
// skip for already exist case
} else if (ret != NI_ERROR_NONE) {