cor3ntin added inline comments.
================ Comment at: clang/include/clang/Basic/TokenKinds.h:87-93 +/// Return true if this token is a predefined macro +/// unexpandable by MSVC preprocessor. +inline bool isUnexpandableMsMacro(TokenKind K) { + return K == tok::kw___FUNCTION__ || K == tok::kw___FUNCSIG__ || + K == tok::kw_L__FUNCTION__ || K == tok::kw_L__FUNCSIG__ || + K == tok::kw___FUNCDNAME__; +} ---------------- RIscRIpt wrote: > tahonermann wrote: > > cor3ntin wrote: > > > tahonermann wrote: > > > > RIscRIpt wrote: > > > > > tahonermann wrote: > > > > > > > > > > > Thanks, I like the name. But shouldn't we reflect that we are > > > > > referring to only Microsoft (unexpandable) macros? How about > > > > > `isFunctionLocalPredefinedMsMacro`? > > > > I don't think the Microsoft association is meaningful. Sure, some of > > > > the predefined macros are only treated differently when compiling in > > > > Microsoft mode, but some of those macros aren't Microsoft specific. > > > > Also, there might be macros provided by other implementations that > > > > we'll want to emulate some day. > > > I think it is, there is currently no way to link > > > `isFunctionLocalPredefinedMacro` to the MS feature. "MSPredefinedMacro" > > > is pretty self explanatory, same reason we most often - but not always - > > > use GNU in the name of function related to GNU extensions. > > > There are enough similar-sounding features and extensions that we should > > > try to make it clear which feature we are talking about. > > Perhaps we still haven't found the right name then. With the name that I've > > been advocating, this function should also return true for > > `tok::kw___PRETTY_FUNCTION__` even though that macro should not expand to > > something that can be concatenated with other string literals (whether > > compiling in Microsoft mode or not). > > > > The Microsoft extension is the localized expansion to a string literal that > > can be concatenated with other string literals. We probably should isolate > > the conditions for that behavior to one place and if we do that, then I > > guess naming this function as specific to Microsoft mode is ok; we can > > always rename it later if it gets used for non-Microsoft extensions. > > > > Here is my suggestion then: > > // Return true if the token corresponds to a function local predefined > > // macro that, in Microsoft modes, expands to a string literal (that can > > // then be concatenated with other string literals). > > inline bool isMsFunctionLocalStringLiteralMacro(TokenKind K, const > > LangOptions &langOpts) { > > return langOpts.MicrosoftExt && ( > > K == tok::kw___FUNCTION__ || K == tok::kw_L__FUNCTION__ || > > K == tok::kw___FUNCSIG__ || K == tok::kw_L__FUNCSIG__ || > > K == tok::kw___FUNCDNAME__); > > } > > > > This will avoid the need for callers to check for `MicrosoftExt`; that is > > what I really want to avoid since it is easy to forget to do that check. > 1. By requiring user to pass `LangOptions` I think we can remove MS > association (implying that there could be other non-msft cases in the future) > 2. We would have to include a `LangOptions.h` in `TokenKinds.h`, are we ok > with this? Alternatively while this function is for msft cases only, we could > pass `bool MicrosoftExt` > > Personally, I like version with `LangOptions` and removal of `MS`. > By requiring user to pass LangOptions I think we can remove MS association I don't think there is any motivation to future proof against hypotheticals, we can always refactor later > We would have to include a LangOptions.h in TokenKinds.h This makes me uneasy, but i think we can move the function to `LiteralSupport.h` and include that in `ParseExpr.cpp`. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153914/new/ https://reviews.llvm.org/D153914 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits