Current Path : /compat/linux/proc/68247/root/usr/src/contrib/llvm/tools/clang/include/clang/Driver/ |
FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64 |
Current File : //compat/linux/proc/68247/root/usr/src/contrib/llvm/tools/clang/include/clang/Driver/Types.h |
//===--- Types.h - Input & Temporary Driver Types ---------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef CLANG_DRIVER_TYPES_H_ #define CLANG_DRIVER_TYPES_H_ #include "clang/Driver/Phases.h" namespace clang { namespace driver { namespace types { enum ID { TY_INVALID, #define TYPE(NAME, ID, PP_TYPE, TEMP_SUFFIX, FLAGS) TY_##ID, #include "clang/Driver/Types.def" #undef TYPE TY_LAST }; /// getTypeName - Return the name of the type for \arg Id. const char *getTypeName(ID Id); /// getPreprocessedType - Get the ID of the type for this input when /// it has been preprocessed, or INVALID if this input is not /// preprocessed. ID getPreprocessedType(ID Id); /// getTypeTempSuffix - Return the suffix to use when creating a /// temp file of this type, or null if unspecified. const char *getTypeTempSuffix(ID Id); /// onlyAssembleType - Should this type only be assembled. bool onlyAssembleType(ID Id); /// onlyPrecompileType - Should this type only be precompiled. bool onlyPrecompileType(ID Id); /// canTypeBeUserSpecified - Can this type be specified on the /// command line (by the type name); this is used when forwarding /// commands to gcc. bool canTypeBeUserSpecified(ID Id); /// appendSuffixForType - When generating outputs of this type, /// should the suffix be appended (instead of replacing the existing /// suffix). bool appendSuffixForType(ID Id); /// canLipoType - Is this type acceptable as the output of a /// universal build (currently, just the Nothing, Image, and Object /// types). bool canLipoType(ID Id); /// isAcceptedByClang - Can clang handle this input type. bool isAcceptedByClang(ID Id); /// isOnlyAcceptedByClang - Is clang the only compiler that can handle this /// input type. bool isOnlyAcceptedByClang(ID Id); /// isCXX - Is this a "C++" input (C++ and Obj-C++ sources and headers). bool isCXX(ID Id); /// isObjC - Is this an "ObjC" input (Obj-C and Obj-C++ sources and headers). bool isObjC(ID Id); /// lookupTypeForExtension - Lookup the type to use for the file /// extension \arg Ext. ID lookupTypeForExtension(const char *Ext); /// lookupTypeForTypSpecifier - Lookup the type to use for a user /// specified type name. ID lookupTypeForTypeSpecifier(const char *Name); /// getNumCompilationPhases - Return the complete number of phases /// to be done for this type. unsigned getNumCompilationPhases(ID Id); /// getCompilationPhase - Return the \args N th compilation phase to /// be done for this type. phases::ID getCompilationPhase(ID Id, unsigned N); /// lookupCXXTypeForCType - Lookup CXX input type that corresponds to given /// C type (used for clang++ emulation of g++ behaviour) ID lookupCXXTypeForCType(ID Id); } // end namespace types } // end namespace driver } // end namespace clang #endif