1257b2971SCaroline Concatto //===- FrontendOptions.cpp ------------------------------------------------===//
2257b2971SCaroline Concatto //
3257b2971SCaroline Concatto // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4257b2971SCaroline Concatto // See https://llvm.org/LICENSE.txt for license information.
5257b2971SCaroline Concatto // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6257b2971SCaroline Concatto //
7257b2971SCaroline Concatto //===----------------------------------------------------------------------===//
81e462fafSAndrzej Warzynski //
91e462fafSAndrzej Warzynski // Coding style: https://mlir.llvm.org/getting_started/DeveloperGuide/
101e462fafSAndrzej Warzynski //
111e462fafSAndrzej Warzynski //===----------------------------------------------------------------------===//
12257b2971SCaroline Concatto 
13257b2971SCaroline Concatto #include "flang/Frontend/FrontendOptions.h"
144c5906cfSCaroline Concatto 
154c5906cfSCaroline Concatto using namespace Fortran::frontend;
164c5906cfSCaroline Concatto 
isFixedFormSuffix(llvm::StringRef suffix)17cea3abc2SAndrzej Warzynski bool Fortran::frontend::isFixedFormSuffix(llvm::StringRef suffix) {
18cea3abc2SAndrzej Warzynski   // Note: Keep this list in-sync with flang/test/lit.cfg.py
19dc14e89aSAndrzej Warzynski   return suffix == "f77" || suffix == "f" || suffix == "F" || suffix == "ff" ||
20dc14e89aSAndrzej Warzynski       suffix == "for" || suffix == "FOR" || suffix == "fpp" || suffix == "FPP";
21cea3abc2SAndrzej Warzynski }
22cea3abc2SAndrzej Warzynski 
isFreeFormSuffix(llvm::StringRef suffix)23cea3abc2SAndrzej Warzynski bool Fortran::frontend::isFreeFormSuffix(llvm::StringRef suffix) {
24cea3abc2SAndrzej Warzynski   // Note: Keep this list in-sync with flang/test/lit.cfg.py
25cea3abc2SAndrzej Warzynski   // TODO: Add Cuda Fortan files (i.e. `*.cuf` and `*.CUF`).
26dc14e89aSAndrzej Warzynski   return suffix == "f90" || suffix == "F90" || suffix == "ff90" ||
27dc14e89aSAndrzej Warzynski       suffix == "f95" || suffix == "F95" || suffix == "ff95" ||
28dc14e89aSAndrzej Warzynski       suffix == "f03" || suffix == "F03" || suffix == "f08" ||
29dc14e89aSAndrzej Warzynski       suffix == "F08" || suffix == "f18" || suffix == "F18";
30cea3abc2SAndrzej Warzynski }
31cea3abc2SAndrzej Warzynski 
isToBePreprocessed(llvm::StringRef suffix)321e462fafSAndrzej Warzynski bool Fortran::frontend::isToBePreprocessed(llvm::StringRef suffix) {
33b83a4450SAndrzej Warzynski   return suffix == "F" || suffix == "FOR" || suffix == "fpp" ||
34b83a4450SAndrzej Warzynski       suffix == "FPP" || suffix == "F90" || suffix == "F95" ||
35b83a4450SAndrzej Warzynski       suffix == "F03" || suffix == "F08" || suffix == "F18";
36b83a4450SAndrzej Warzynski }
37b83a4450SAndrzej Warzynski 
getInputKindForExtension(llvm::StringRef extension)381e462fafSAndrzej Warzynski InputKind FrontendOptions::getInputKindForExtension(llvm::StringRef extension) {
39443d6957SFaris Rehman   if (isFixedFormSuffix(extension) || isFreeFormSuffix(extension)) {
40443d6957SFaris Rehman     return Language::Fortran;
41443d6957SFaris Rehman   }
42b9f3b7f8SAndrzej Warzynski 
43b9f3b7f8SAndrzej Warzynski   if (extension == "bc" || extension == "ll")
44b9f3b7f8SAndrzej Warzynski     return Language::LLVM_IR;
45*cc3c6b61SAndrzej Warzynski   if (extension == "fir" || extension == "mlir")
46*cc3c6b61SAndrzej Warzynski     return Language::MLIR;
47b9f3b7f8SAndrzej Warzynski 
48443d6957SFaris Rehman   return Language::Unknown;
494c5906cfSCaroline Concatto }
50