diff options
author | The Phantom Derpstorm <phdofthehouse@gmail.com> | 2024-06-12 03:16:02 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-12 09:16:02 +0200 |
commit | 5989450e0061dce8cff89d8acfdd5225c14cd065 (patch) | |
tree | f27a31bdd90497b029718f283d0702fec58e8477 /clang/test/Preprocessor/embed_preprocess_to_file.c | |
parent | b83f8c75e4cccf25abbe4ad76406ba0c382bf336 (diff) | |
download | llvm-5989450e0061dce8cff89d8acfdd5225c14cd065.zip llvm-5989450e0061dce8cff89d8acfdd5225c14cd065.tar.gz llvm-5989450e0061dce8cff89d8acfdd5225c14cd065.tar.bz2 |
[clang][Sema, Lex, Parse] Preprocessor embed in C and C++ (and Obj-C and Obj-C++ by-proxy) (#68620)
This commit implements the entirety of the now-accepted [N3017 -
Preprocessor
Embed](https://www.open-std.org/jtc1/sc22/wg14/www/docs/n3017.htm) and
its sister C++ paper [p1967](https://wg21.link/p1967). It implements
everything in the specification, and includes an implementation that
drastically improves the time it takes to embed data in specific
scenarios (the initialization of character type arrays). The mechanisms
used to do this are used under the "as-if" rule, and in general when the
system cannot detect it is initializing an array object in a variable
declaration, will generate EmbedExpr AST node which will be expanded
by AST consumers (CodeGen or constant expression evaluators) or
expand embed directive as a comma expression.
---------
Co-authored-by: Aaron Ballman <aaron@aaronballman.com>
Co-authored-by: cor3ntin <corentinjabot@gmail.com>
Co-authored-by: H. Vetinari <h.vetinari@gmx.com>
Co-authored-by: Podchishchaeva, Mariya <mariya.podchishchaeva@intel.com>
Diffstat (limited to 'clang/test/Preprocessor/embed_preprocess_to_file.c')
-rw-r--r-- | clang/test/Preprocessor/embed_preprocess_to_file.c | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/clang/test/Preprocessor/embed_preprocess_to_file.c b/clang/test/Preprocessor/embed_preprocess_to_file.c new file mode 100644 index 0000000..9895d95 --- /dev/null +++ b/clang/test/Preprocessor/embed_preprocess_to_file.c @@ -0,0 +1,39 @@ +// RUN: %clang_cc1 -std=c23 %s -E --embed-dir=%S/Inputs | FileCheck %s --check-prefix EXPANDED +// RUN: %clang_cc1 -std=c23 %s -E -dE --embed-dir=%S/Inputs | FileCheck %s --check-prefix DIRECTIVE + +// Ensure that we correctly preprocess to a file, both with expanding embed +// directives fully and with printing the directive instead. +const char data[] = { +#embed <jk.txt> if_empty('a', 'b') clang::offset(0) limit(1) suffix(, 'a', 0) prefix('h',) +}; + +// EXPANDED: const char data[] = {'h',106 , 'a', 0}; +// DIRECTIVE: const char data[] = { +// DIRECTIVE-NEXT: #embed <jk.txt> if_empty('a', 'b') limit(1) clang::offset(0) prefix('h',) suffix(, 'a', 0) /* clang -E -dE */ +// DIRECTIVE-NEXT: }; + +const char more[] = { +#embed <media/empty> if_empty('a', 'b') +}; + +// EXPANDED: const char more[] = {'a', 'b'} +// DIRECTIVE: const char more[] = { +// DIRECTIVE-NEXT: #embed <media/empty> if_empty('a', 'b') /* clang -E -dE */ +// DIRECTIVE-NEXT: }; + +const char even_more[] = { + 1, 2, 3, +#embed <jk.txt> prefix(4, 5,) suffix(, 6, 7) + , 8, 9, 10 +}; + +// EXPANDED: const char even_more[] = { +// EXPANDED-NEXT: 1, 2, 3,4, 5,106, 107 , 6, 7 , 8, 9, 10 +// EXPANDED-EMPTY: +// EXPANDED-EMPTY: +// EXPANDED-NEXT: }; +// DIRECTIVE: const char even_more[] = { +// DIRECTIVE-NEXT: 1, 2, 3, +// DIRECTIVE-NEXT: #embed <jk.txt> prefix(4, 5,) suffix(, 6, 7) /* clang -E -dE */ +// DIRECTIVE-NEXT: , 8, 9, 10 +// DIRECTIVE-NEXT: }; |