object-introspection/tools/OILGen.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

125 lines
3.7 KiB
C++
Raw Normal View History

2022-12-19 14:37:51 +00:00
/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <glog/logging.h>
2023-01-19 11:36:10 +00:00
#include <cstdlib>
2022-12-19 14:37:51 +00:00
#include <filesystem>
#include <iostream>
2023-04-26 16:20:53 +01:00
#include "oi/OICodeGen.h"
#include "oi/OIGenerator.h"
#include "oi/OIOpts.h"
2022-12-19 14:37:51 +00:00
namespace fs = std::filesystem;
using namespace oi::detail;
2022-12-19 14:37:51 +00:00
constexpr static OIOpts opts{
OIOpt{'h', "help", no_argument, nullptr, "Print this message and exit."},
OIOpt{'o', "output", required_argument, "<file>",
"Write output(s) to file(s) with this prefix."},
2022-12-19 14:37:51 +00:00
OIOpt{'c', "config-file", required_argument, "<oid.toml>",
"Path to OI configuration file."},
OIOpt{'d', "debug-level", required_argument, "<level>",
"Verbose level for logging"},
OIOpt{'j', "dump-jit", optional_argument, "<jit.cpp>",
2022-12-19 14:37:51 +00:00
"Write generated code to a file (for debugging)."},
OIOpt{'e', "exit-code", no_argument, nullptr,
"Return a bad exit code if nothing is generated."},
OIOpt{'p', "pic", no_argument, nullptr,
"Generate position independent code."},
2022-12-19 14:37:51 +00:00
};
void usage() {
std::cerr << "usage: oilgen ARGS INPUT_OBJECT" << std::endl;
std::cerr << opts;
std::cerr << std::endl
<< "You probably shouldn't be calling this application directly. "
"It's meant to be"
<< std::endl
<< "called by a clang plugin automatically with BUCK." << std::endl;
}
int main(int argc, char* argv[]) {
google::InitGoogleLogging(argv[0]);
FLAGS_minloglevel = 0;
FLAGS_stderrthreshold = 0;
fs::path outputPath = "a.o";
fs::path configFilePath = "/usr/local/share/oi/base.oid.toml";
fs::path sourceFileDumpPath = "";
bool exitCode = false;
bool pic = false;
2022-12-19 14:37:51 +00:00
int c;
while ((c = getopt_long(argc, argv, opts.shortOpts(), opts.longOpts(),
nullptr)) != -1) {
switch (c) {
case 'h':
usage();
return EXIT_SUCCESS;
2022-12-19 14:37:51 +00:00
case 'o':
outputPath = optarg;
break;
case 'c':
configFilePath = optarg;
break;
case 'd':
google::LogToStderr();
google::SetStderrLogging(google::INFO);
google::SetVLOGLevel("*", atoi(optarg));
// Upstream glog defines `GLOG_INFO` as 0 https://fburl.com/ydjajhz0,
// but internally it's defined as 1 https://fburl.com/code/9fwams75
gflags::SetCommandLineOption("minloglevel", "0");
break;
case 'j':
2022-12-19 14:37:51 +00:00
sourceFileDumpPath = optarg != nullptr ? optarg : "jit.cpp";
break;
case 'e':
exitCode = true;
break;
case 'p':
pic = true;
break;
2022-12-19 14:37:51 +00:00
}
}
if (optind >= argc) {
usage();
return EXIT_FAILURE;
}
fs::path primaryObject = argv[optind];
2023-01-19 11:36:10 +00:00
if ((setenv("DRGN_ENABLE_TYPE_ITERATOR", "1", 1)) < 0) {
LOG(ERROR) << "Failed to set environment variable\
2023-01-19 11:36:10 +00:00
DRGN_ENABLE_TYPE_ITERATOR\n";
exit(EXIT_FAILURE);
}
2022-12-19 14:37:51 +00:00
OIGenerator oigen;
oigen.setOutputPath(std::move(outputPath));
oigen.setConfigFilePath(std::move(configFilePath));
oigen.setSourceFileDumpPath(sourceFileDumpPath);
oigen.setFailIfNothingGenerated(exitCode);
oigen.setUsePIC(pic);
2022-12-19 14:37:51 +00:00
SymbolService symbols(primaryObject);
return oigen.generate(primaryObject, symbols);
2022-12-19 14:37:51 +00:00
}