[clang] [clang-tools-extra] [clang][modules] Serialize `CodeGenOptions` (PR #146422)
Ben Langmuir via cfe-commits
cfe-commits at lists.llvm.org
Tue Jul 1 10:38:04 PDT 2025
================
@@ -1181,8 +1183,9 @@ class Preprocessor {
public:
Preprocessor(const PreprocessorOptions &PPOpts, DiagnosticsEngine &diags,
- const LangOptions &LangOpts, SourceManager &SM,
- HeaderSearch &Headers, ModuleLoader &TheModuleLoader,
+ const LangOptions &LangOpts, const CodeGenOptions &CGOPts,
----------------
benlangmuir wrote:
Having the `Preprocessor` keep a `CodeGenOptions` isn't technically a layering violation, but it feels like a bit of code smell to me. Looking through this PR, it seems the only places that actually use this are
1. `clang::InitializePreprocessor`: was there a reason you removed the `CodeGenOptions` parameter? That seems like a better design to me to have the preprocessor be independent of code gen opts after initialization.
2. `PCHValidator::ReadCodeGenOptions`: what if we stored the `CodeGenOptions` on the `ASTReader` instead? That seems to align better with the fact we are doing this in order to (de)serialize and check these options.
3. `ASTWriter`. Similarly, I'd rather have the ASTWriter keep the codegen opts not the preprocessor.
https://github.com/llvm/llvm-project/pull/146422
More information about the cfe-commits
mailing list