//===- orc-rt-executor.cpp ------------------------------------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
//
// Contains the orc-rt-executor test tool. This is a "blank executable" that
// links the ORC runtime and can accept code from a JIT controller like lii or
// llvm-jitlink.
//
//===----------------------------------------------------------------------===//
#include <cstring>
#include <iostream>
#include <optional>
#include <string_view>
void printHelp(std::string_view ProgName, std::ostream &OS) {
OS << "usage: " << ProgName << " [help] [<mode>] <program arguments>...\n"
<< " <mode> -- specify how to listen for JIT'd program\n"
<< " filedesc=<in>,<out> -- read from <in> filedesc, write to out\n"
<< " tcp=<host>:<port> -- listen on the given host/port\n"
<< " help -- print help and exit\n"
<< "\n"
<< " Notes:\n"
<< " Program arguments will be made available to the JIT controller.\n"
<< " When running a JIT'd program containing a main function the\n"
<< " controller may choose to pass these on to main, however\n"
<< " orc-rt-executor does not enforce this.\n";
}
int main(int argc, char *argv[]) {
if (argc < 2) {
printHelp("orc-rt-executor", std::cerr);
std::cerr << "error: insufficient arguments.\n";
exit(1);
}
if (!strcmp(argv[1], "help")) {
printHelp(argv[0], std::cerr);
exit(0);
}
std::cerr << "error: One day I will be a real program, but I am not yet.\n";
return 0;
}