xref: /llvm-project/flang/lib/Frontend/FrontendOptions.cpp (revision 4ad7279392653c0bcf564799ffb3f7e20ed4ef00)
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" ||
2074d5c3c0SPeter Steinfeld          suffix == "for" || suffix == "FOR" || suffix == "fpp" ||
2174d5c3c0SPeter Steinfeld          suffix == "FPP";
22cea3abc2SAndrzej Warzynski }
23cea3abc2SAndrzej Warzynski 
isFreeFormSuffix(llvm::StringRef suffix)24cea3abc2SAndrzej Warzynski bool Fortran::frontend::isFreeFormSuffix(llvm::StringRef suffix) {
25cea3abc2SAndrzej Warzynski   // Note: Keep this list in-sync with flang/test/lit.cfg.py
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" ||
29*4ad72793SPeter Klausler          suffix == "F08" || suffix == "f18" || suffix == "F18" ||
30*4ad72793SPeter Klausler          suffix == "cuf" || suffix == "CUF";
31cea3abc2SAndrzej Warzynski }
32cea3abc2SAndrzej Warzynski 
isToBePreprocessed(llvm::StringRef suffix)331e462fafSAndrzej Warzynski bool Fortran::frontend::isToBePreprocessed(llvm::StringRef suffix) {
34b83a4450SAndrzej Warzynski   return suffix == "F" || suffix == "FOR" || suffix == "fpp" ||
35b83a4450SAndrzej Warzynski          suffix == "FPP" || suffix == "F90" || suffix == "F95" ||
36*4ad72793SPeter Klausler          suffix == "F03" || suffix == "F08" || suffix == "F18" ||
37*4ad72793SPeter Klausler          suffix == "CUF";
38*4ad72793SPeter Klausler }
39*4ad72793SPeter Klausler 
isCUDAFortranSuffix(llvm::StringRef suffix)40*4ad72793SPeter Klausler bool Fortran::frontend::isCUDAFortranSuffix(llvm::StringRef suffix) {
41*4ad72793SPeter Klausler   return suffix == "cuf" || suffix == "CUF";
42b83a4450SAndrzej Warzynski }
43b83a4450SAndrzej Warzynski 
getInputKindForExtension(llvm::StringRef extension)441e462fafSAndrzej Warzynski InputKind FrontendOptions::getInputKindForExtension(llvm::StringRef extension) {
45443d6957SFaris Rehman   if (isFixedFormSuffix(extension) || isFreeFormSuffix(extension)) {
46443d6957SFaris Rehman     return Language::Fortran;
47443d6957SFaris Rehman   }
48b9f3b7f8SAndrzej Warzynski 
49b9f3b7f8SAndrzej Warzynski   if (extension == "bc" || extension == "ll")
50b9f3b7f8SAndrzej Warzynski     return Language::LLVM_IR;
51cc3c6b61SAndrzej Warzynski   if (extension == "fir" || extension == "mlir")
52cc3c6b61SAndrzej Warzynski     return Language::MLIR;
53b9f3b7f8SAndrzej Warzynski 
54443d6957SFaris Rehman   return Language::Unknown;
554c5906cfSCaroline Concatto }
56