From 1be0d89658fb4ea105583b534e52e752e2a75daf Mon Sep 17 00:00:00 2001 From: Martin Medler Date: Wed, 18 Dec 2024 14:17:16 +0100 Subject: [PATCH] fix(aspect): Patch RecursionError in pcpp Fixes: https://github.com/martis42/depend_on_what_you_use/issues/300 --- third_party/pcpp/recursion_fix.patch | 11 +++++++++++ third_party/pcpp/repository.bzl | 7 +++++++ 2 files changed, 18 insertions(+) create mode 100644 third_party/pcpp/recursion_fix.patch diff --git a/third_party/pcpp/recursion_fix.patch b/third_party/pcpp/recursion_fix.patch new file mode 100644 index 00000000..95ab9233 --- /dev/null +++ b/third_party/pcpp/recursion_fix.patch @@ -0,0 +1,11 @@ +--- pcpp/preprocessor.py ++++ pcpp/preprocessor.py +@@ -558,6 +558,8 @@ class Preprocessor(PreprocessorHooks): + for tok in tokens: + if not hasattr(tok, 'expanded_from'): + tok.expanded_from = [] ++ if len(expanding_from) == 1 and tok.value == expanding_from[0]: ++ return tokens + i = 0 + #print("*** EXPAND MACROS in", "".join([t.value for t in tokens]), "expanding_from=", expanding_from) + #print(tokens) diff --git a/third_party/pcpp/repository.bzl b/third_party/pcpp/repository.bzl index cfc20923..a7cc4e2f 100644 --- a/third_party/pcpp/repository.bzl +++ b/third_party/pcpp/repository.bzl @@ -9,4 +9,11 @@ def pcpp(): urls = [ "https://files.pythonhosted.org/packages/41/07/876153f611f2c610bdb8f706a5ab560d888c938ea9ea65ed18c374a9014a/pcpp-1.30.tar.gz", ], + patches = [ + # Tested for 'cuda.h' by reporter of https://github.com/martis42/depend_on_what_you_use/issues/300 + # Corresponding pcpp issue: https://github.com/ned14/pcpp/issues/72 + # We tested that this patch resolves pcpp issue #72 and all pcpp unit test remain green. + # pcpp will hopefully see development again in 2025 and then we should be able to drop this patch. + Label("//third_party/pcpp:recursion_fix.patch"), + ], )