diff --git a/flang/test/Driver/write-module.f90 b/flang/test/Driver/write-module.f90 new file mode 100644 --- /dev/null +++ b/flang/test/Driver/write-module.f90 @@ -0,0 +1,19 @@ +! RUN: rm -rf %t && mkdir -p %t/mod-dir && cd %t && %f18 -fparse-only %s +! RUN: ls %t/testmodule.mod && not ls %t/mod-dir/testmodule.mod + +! RUN: rm -rf %t && mkdir -p %t/mod-dir && cd %t && %f18 -fparse-only -module mod-dir %s +! RUN: ls %t/mod-dir/testmodule.mod && not ls %t/testmodule.mod + +! RUN: rm -rf %t && mkdir -p %t/mod-dir && cd %t && %f18 -fparse-only -module-dir mod-dir %s +! RUN: ls %t/mod-dir/testmodule.mod && not ls %t/testmodule.mod + +! RUN: rm -rf %t && mkdir -p %t/mod-dir && cd %t && %f18 -fparse-only -J mod-dir %s +! RUN: ls %t/mod-dir/testmodule.mod && not ls %t/testmodule.mod + +! RUN: rm -rf %t && mkdir -p %t/mod-dir && cd %t && %f18 -fparse-only -Jmod-dir %s +! RUN: ls %t/mod-dir/testmodule.mod && not ls %t/testmodule.mod + +module testmodule + type::t2 + end type +end diff --git a/flang/tools/f18/f18.cpp b/flang/tools/f18/f18.cpp --- a/flang/tools/f18/f18.cpp +++ b/flang/tools/f18/f18.cpp @@ -583,6 +583,10 @@ } else if (arg == "-module") { driver.moduleDirectory = args.front(); args.pop_front(); + } else if (arg == "-module-dir") { + driver.moduleDirectory = args.front(); + driver.searchDirectories.push_back(driver.moduleDirectory); + args.pop_front(); } else if (arg == "-module-suffix") { driver.moduleFileSuffix = args.front(); args.pop_front(); @@ -654,7 +658,8 @@ << " -module dir module output directory (default .)\n" << " -flatin interpret source as Latin-1 (ISO 8859-1) " "rather than UTF-8\n" - << " -fsyntax-only parsing and semantics only, no output except messages\n" + << " -fsyntax-only parsing and semantics only, no output " + "except messages\n" << " -funparse parse & reformat only, no code " "generation\n" << " -funparse-with-symbols parse, resolve symbols, and unparse\n" @@ -691,6 +696,14 @@ args.pop_front(); } else if (arg.substr(0, 2) == "-I") { driver.searchDirectories.push_back(arg.substr(2)); + } else if (arg == "-J") { + driver.F18_FCArgs.push_back(args.front()); + driver.moduleDirectory = args.front(); + driver.searchDirectories.push_back(driver.moduleDirectory); + args.pop_front(); + } else if (arg.substr(0, 2) == "-J") { + driver.moduleDirectory = arg.substr(2); + driver.searchDirectories.push_back(driver.moduleDirectory); } } }