From 2b4c9bc4d489a4be1c5aa1924fba542dc80ab0c9 Mon Sep 17 00:00:00 2001 From: Andrzej Warzynski Date: Wed, 2 Jun 2021 21:53:02 +0100 Subject: [PATCH] [flang][driver] Add checks for missing option arguments With this patch, the following invocation of the frontend driver will return an error: ``` flang-new -fc1 input-file.f90 -o ``` Similar logic applies to other options that require arguments. Similar checks are already available in the compiler driver, flang-new (that's implemented in clangDriver). Differential Revision: https://reviews.llvm.org/D103554 --- flang/lib/Frontend/CompilerInvocation.cpp | 7 +++++++ flang/test/Driver/missing-arg.f90 | 21 +++++++++++++++++++++ 2 files changed, 28 insertions(+) create mode 100644 flang/test/Driver/missing-arg.f90 diff --git a/flang/lib/Frontend/CompilerInvocation.cpp b/flang/lib/Frontend/CompilerInvocation.cpp index 1d18dda5e7ee..6d9a3a7f3194 100644 --- a/flang/lib/Frontend/CompilerInvocation.cpp +++ b/flang/lib/Frontend/CompilerInvocation.cpp @@ -501,6 +501,13 @@ bool CompilerInvocation::CreateFromArgs(CompilerInvocation &res, llvm::opt::InputArgList args = opts.ParseArgs( commandLineArgs, missingArgIndex, missingArgCount, includedFlagsBitmask); + // Check for missing argument error. + if (missingArgCount) { + diags.Report(clang::diag::err_drv_missing_argument) + << args.getArgString(missingArgIndex) << missingArgCount; + success = false; + } + // Issue errors on unknown arguments for (const auto *a : args.filtered(clang::driver::options::OPT_UNKNOWN)) { auto argString = a->getAsString(args); diff --git a/flang/test/Driver/missing-arg.f90 b/flang/test/Driver/missing-arg.f90 new file mode 100644 index 000000000000..3a16542e04e8 --- /dev/null +++ b/flang/test/Driver/missing-arg.f90 @@ -0,0 +1,21 @@ +! Make sure that frontend driver options that require arguments are +! correctly rejected when the argument value is missing. + +! REQUIRES: new-flang-driver + +!----------- +! RUN lines +!----------- +! RUN: not %flang_fc1 -E %s -o 2>&1 | FileCheck %s +! RUN: not %flang_fc1 -E %s -U 2>&1 | FileCheck %s +! RUN: not %flang_fc1 -E %s -D 2>&1 | FileCheck %s +! RUN: not %flang_fc1 -E %s -I 2>&1 | FileCheck %s +! RUN: not %flang_fc1 -E %s -J 2>&1 | FileCheck %s +! RUN: not %flang_fc1 -E %s -module-dir 2>&1 | FileCheck %s +! RUN: not %flang_fc1 -E %s -module-suffix 2>&1 | FileCheck %s +! RUN: not %flang_fc1 -E %s -fintrinsic-modules-path 2>&1 | FileCheck %s + +!----------------------- +! EXPECTED OUTPUT +!----------------------- +! CHECK: error: argument to '-{{.*}}' is missing (expected 1 value)