* Copyright (c) 2021 Huawei Device Co., Ltd.
*
* HDF is dual licensed: you can use it either under the terms of
* the GPL, or the BSD license, at your option.
* See the LICENSE file in the root of this repository for complete details.
*/
#include "codegen/code_generator.h"
#include "parser/parser.h"
#include "preprocessor/preprocessor.h"
#include "util/file.h"
#include "util/logger.h"
#include "util/options.h"
using namespace OHOS::HDI;
int main(int argc, char **argv)
{
Options &options = Options::GetInstance().Parse(argc, argv);
if (options.HasErrors()) {
options.ShowErrors();
return 0;
}
if (options.DoShowUsage()) {
options.ShowUsage();
return 0;
}
if (options.DoShowVersion()) {
options.ShowVersion();
return 0;
}
if (!options.DoCompile()) {
return 0;
}
if (options.DoGetHashKey()) {
for (const auto &sourceFile : options.GetSourceFiles()) {
std::unique_ptr<File> idlFile = std::make_unique<File>(sourceFile, int(File::READ));
if (!idlFile->IsValid()) {
Logger::E("hdi-gen", "open idl file failed!");
return -1;
}
printf("%s:%lu\n", idlFile->GetPath().string(), idlFile->GetHashKey());
}
return 0;
}
Preprocessor preprocessor;
std::vector<String> sourceFiles;
if (!preprocessor.Preprocess(sourceFiles)) {
Logger::E("MAIN", "preprocess failed");
}
Parser parser;
if (!parser.Parse(sourceFiles)) {
Logger::E("MAIN", "parse file failed");
return -1;
}
if (options.DoDumpAST()) {
for (const auto &astPair : parser.GetAllAst()) {
printf("%s\n", astPair.second->Dump("").string());
}
}
if (!options.DoGenerateCode()) {
return 0;
}
if (!CodeGenerator(parser.GetAllAst()).Generate()) {
Logger::E("hdi-gen", "Generate \"%s\" codes failed.", options.GetTargetLanguage().string());
return -1;
}
return 0;
}