llvm/compiler-rt/lib/orc/tests/tools/orc-rt-executor.cpp

//===- 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;
}