feat: add missing KF6 framework recipes

This commit is contained in:
2026-05-07 07:53:26 +01:00
parent d8d498f831
commit a69f479b52
2374 changed files with 2610246 additions and 0 deletions
@@ -0,0 +1,584 @@
#pragma once
#include <cassert>
#include <assert.h>
#include "assert.h"
#include "assert.hpp" // abc
#include "path/assert.hpp"
#include "assert.h"a
#include "assert.h" a
#include <cassert>a
#include <cassert> a
#include FOO() error
#include_next <cassert> a
#include_next <cassert> <beginfold id='1'>/*</beginfold id='1'> a
<endfold id='1'>*/</endfold id='1'> b
#include PATH_IN_MACRO
#include PATH_IN_MACRO()
#include PATH_IN_MACRO(a, b)
#define SOME_VAR 1
#<beginfold id='2'></beginfold id='2'>ifdef SOME_VAR
#define MULTILINE_MACRO one \
two \
three
# define MULTILINE_MACRO_TEXT \
<beginfold id='1'>/*</beginfold id='1'> NOTE The contents of macro is too green :D <endfold id='1'>*/</endfold id='1'> \
char const s[] = "a\\b" \
"c\nd" \
std::uint##x##_t \
std::vector<beginfold id='1'>/*</beginfold id='1'><endfold id='1'>*/</endfold id='1'><T> \
std::chrono::<beginfold id='1'>/*</beginfold id='1'>milli<endfold id='1'>*/</endfold id='1'>seconds
# define VARIADIC(a, ...) \
f(a##a) \
f(__VA_ARGS__) \
f(#__VA_ARGS__) \
f(__VA_ARGS__) \
f(0 __VA_OPT__(,) __VA_ARGS__) \
x __VA_OPT__(= { __VA_ARGS__ })
# define MACRO() BAD \ ESCAPED
# error dds
# warning dds
# line 2 "file.cpp"
# define A(x, y) x##y x#y
// OK(L, a) -> L"a"
# define OK(x, y) x###y
# define BAD(x, y) x####y
# define A <beginfold id='1'>/*</beginfold id='1'> multi line
with comment <endfold id='1'>*/</endfold id='1'> expr
# define A <beginfold id='1'>/*</beginfold id='1'> multi line
with comment <endfold id='1'>*/</endfold id='1'>
23
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> // x
#42 // gcc extension = #line 42
// error
#wrong
# wrong
#<endfold id='2'>endif</endfold id='2'> x
#<beginfold id='2'></beginfold id='2'>if DS()
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> x
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> <beginfold id='1'>/*</beginfold id='1'> <endfold id='1'>*/</endfold id='1'>x
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> <beginfold id='1'>/*</beginfold id='1'> x
y <endfold id='1'>*/</endfold id='1'> z
#<endfold id='2'>endif</endfold id='2'>
// check that _XXX defines work, bug 397766
#<beginfold id='2'></beginfold id='2'>ifndef _HEADER_GUARD
#define _HEADER_GUARD 1
#<endfold id='2'>endif</endfold id='2'>
#<beginfold id='2'></beginfold id='2'>ifdef _HEADER_GUARD
#<beginfold id='2'></beginfold id='2'>if (_HEADER_GUARD >= 1)
#<endfold id='2'>endif</endfold id='2'>
#<endfold id='2'>endif</endfold id='2'>
static int g_global;
template<class T, typename U, template<class> class = std::is_pointer>
struct class1
: private std::vector<T>, public U
<beginfold id='3'>{</beginfold id='3'>
class1()
try
: _member1(xxx)
<beginfold id='3'>{</beginfold id='3'><endfold id='3'>}</endfold id='3'>
catch(...)
<beginfold id='3'>{</beginfold id='3'><endfold id='3'>}</endfold id='3'>
class1(class1&&) = default;
~class1()
<beginfold id='3'>{</beginfold id='3'><endfold id='3'>}</endfold id='3'>
void foo() <beginfold id='3'>{</beginfold id='3'> return; <endfold id='3'>}</endfold id='3'>
void foo() const <beginfold id='3'>{</beginfold id='3'> return; <endfold id='3'>}</endfold id='3'>
void foo() noexcept <beginfold id='3'>{</beginfold id='3'> return; <endfold id='3'>}</endfold id='3'>
void foo() const noexcept <beginfold id='3'>{</beginfold id='3'> return; <endfold id='3'>}</endfold id='3'>
virtual void foo() const noexcept <beginfold id='3'>{</beginfold id='3'> return; <endfold id='3'>}</endfold id='3'>
static void foo() <beginfold id='3'>{</beginfold id='3'> return; <endfold id='3'>}</endfold id='3'>
constexpr static void foo() const
noexcept(noexcept(std::is_pointer<U>::value)) override
<beginfold id='3'>{</beginfold id='3'>
xxx::template ttt<U>::type <beginfold id='3'>{</beginfold id='3'><endfold id='3'>}</endfold id='3'>;
xxx.template get<U>();
xxx.std::rdbuf();
auto x = C<'a'> + y;
<endfold id='3'>}</endfold id='3'>
int operator->*(T (C::*m)(int));
operator value_t ();
private:
protected:
public:
value_type _member1; // NOTE internal ?
value_type __internal;
value_type internal__;
value_type _M_internal;
value_t member2_;
value_type m_member3;
static int s_static;
static constexpr int s_static;
static inline int s_static;
static inline constexpr int s_static;
<endfold id='3'>}</endfold id='3'>;
constexpr struct : xyz
<beginfold id='3'>{</beginfold id='3'>
using xyz::xyz;
using xyz::operator=;
int a : 1;
int b : 7;
<endfold id='3'>}</endfold id='3'> x <beginfold id='3'>{</beginfold id='3'><endfold id='3'>}</endfold id='3'>;
template<class T>
using is_pointer = std::is_pointer<T>::type;
template<class T>
constexpr auto is_pointer_v = std::is_pointer<T>::value;
uint64_t namespaces()
<beginfold id='3'>{</beginfold id='3'>
std::vector<T>;
boost::vector<T>;
detail::vector<T>;
details::vector<T>;
aux::vector<T>;
internals::vector<T>;
other::vector<T>;
<endfold id='3'>}</endfold id='3'>
task<> tcp_echo_server() <beginfold id='3'>{</beginfold id='3'>
char data[1024];
for (;;) <beginfold id='3'>{</beginfold id='3'>
size_t n = co_await socket.async_read_some(buffer(data));
co_await async_write(socket, buffer(data, n));
<endfold id='3'>}</endfold id='3'>
<endfold id='3'>}</endfold id='3'>
#<beginfold id='2'></beginfold id='2'>if 1
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#else</beginfold id='2'> // else
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 0
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#else</beginfold id='2'> // else
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 1
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#elif</beginfold id='2'> 1
double foo(const A);
#elif 0
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 0
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#elif 1</beginfold id='2'>
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#elif</beginfold id='2'> 0
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 0
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#elif</beginfold id='2'> a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif 0
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#elif</beginfold id='2'> a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> // else
double foo(const A);
#<endfold id='2'>endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 0 // blah blah
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#elif 1 </beginfold id='2'>// blah blah
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#else</beginfold id='2'> // else
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 0 || a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> // else
double foo(const A);
#<endfold id='2'>endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 1 || a
double foo(const A);
<endfold id='2'></endfold id='2'><beginfold id='2'>#else</beginfold id='2'> // else
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 0 && a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> // else
double foo(const A);
#<endfold id='2'>endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if 1 && a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'> // else
double foo(const A);
#<endfold id='2'>endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif 0
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif 1
double foo(const A);
<endfold id='2'>#endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if a
double foo(const A);
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif a
double foo(const A);
#<endfold id='2'>endif</endfold id='2'> // end
int bar(void*p, void * pp)
<beginfold id='3'>{</beginfold id='3'>
# <beginfold id='2'></beginfold id='2'>if 0
double foo();
<endfold id='2'></endfold id='2'><beginfold id='2'># else</beginfold id='2'> // else
double foo();
<endfold id='2'># endif</endfold id='2'> // end
<endfold id='3'>}</endfold id='3'>
#<beginfold id='2'></beginfold id='2'>if abc 0
double foo();
#<endfold id='2'>endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if xxx
double foo();
#<endfold id='2'></endfold id='2'><beginfold id='2'>else</beginfold id='2'>
double foo();
#<endfold id='2'>endif</endfold id='2'> // end
#<beginfold id='2'></beginfold id='2'>if xxx
double foo();
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif xxx // elseif
double foo();
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif xxx // elseif
double foo();
#<endfold id='2'>endif</endfold id='2'> // end
// error
#
#d
# d
#<beginfold id='2'></beginfold id='2'>if
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif
#<endfold id='2'>endif</endfold id='2'>
#<beginfold id='2'></beginfold id='2'>ifndef
#<endfold id='2'>endif</endfold id='2'>
#<beginfold id='2'></beginfold id='2'>ifdef 0
#<endfold id='2'>endif</endfold id='2'> // end
static uint64_t intWithSuffix = 42ull;
static long intWithSuffixAndPrefix = 0b0101L;
static int octNum = 07232;
static int invalidOctNum = 09231;
static uint64_t hexNum = 0xDEADBEEF42;
static uint64_t invalidHexNum = 0xGLDFKG;
static char binNum = 0b0101010;
static int64_t intWithSuffix = -42LL;
static long intWithSuffixAndPrefix = -0b0101L;
static int octNum = -07232;
static int invalidOctNum = -09231;
static int64_t hexNum = -0xDEADBEEF42;
static int64_t invalidHexNum = -0xGLDFKG;
static char binNum = -0b0101010;
static uint64_t intWithSuffixWithSep = 4'2ull;
static long intWithSuffixAndPrefixWithSep = 0b0'10'1L;
static int octNumWithSep = 07'232;
static int invalidOctNumWithSep = 09'23'1;
static uint64_t hexNumWithSep = 0xD'EAD'BE'EF'42;
static uint64_t invalidHexNumWithSep = 0xGLD'FKG;
static char binNumWithSep = 0b0'1010'10;
static uint64_t invalidSep = 42'ull;
static uint64_t invalidSep = 42';
static double d1 = 42.;
static double d2 = .42;
static double d2a = -0.49;
static double d2b = -0.09;
static double d3 = 42.3e1;
static double d4 = .2e-12;
static double d5 = 32.e+12;
static double invalidD1 = 32.e+a12;
static float floatQualifier = 23.123f;
// Hexadecimal floating point (c++17)
static double d6 = 0x1ffp10;
static double d7 = 0X0p-1;
static double d8 = 0x1.p0;
static double d9 = 0xf.p-1L;
static double d10 = 0x0.123p-1;
static double d11 = 0xa.bp10l;
static double invalidD2 = 0x0.123p-a;
static float floatQualifier = 0xf.p-1f;
60min; // c++17
60.min;
60.3min;
0x1ffp10min;
2us
2d; // c++20
23._f
23._fd
2.3_f
2.3_fd
2._f
2._fd
2e4_f
2e4_fd
// error
23.fd
2e_fd
2e
1.y
1.0_E+2.0
1.0_E +2.0 // ok
1_p+2
1_p +2 // ok
4s.count()
4s. count()
4s .count() // ok
// float suffix
1.2f
1.2f3
1.2f32 // C++23
12f32
12BF32
12BF16
12.BF16 // C++23
static bool yes = true;
static bool no = false;
// *char*
static const char c1 = 'c';
static const char c1a = u8'c'; // utf-8 char (c++17)
static const char16_t c1b = u'c';
static const char32_t c1c = U'c';
static const wchar_t c1d = L'c';
static const char c2 = '\n';
static const char c2a = '\120'; // octal
static const char c2b = '\x1f'; // hex
static const char c2c = '\'';
static const char c2d = '\\';
static const wchar_t c2e = L'\x1ff'; // hex
static const wchar_t c2e = U'\x1fffffff'; // hex
// error
'\x123';
'\u1234';
'\U12345678';
U'\u12345';
u'\u123';
U'\U1234567';
U'\U123456789';
U'\x123456789';
// string
static const char* c3 = "string";
static const char* c4 = "\"string\n\t\012\x12\"";
static const char* c5 = "multiline \
string";
static const char* c6 = "multifragment" "other""string";
static const char* c6a = u8"string";
static const char16_t* c6b = u"string";
static const char32_t* c6c = U"string";
static const wchar_t* c6d = L"string";
static const char* rawString1 = R<beginfold id='4'>"(</beginfold id='4'>string<endfold id='4'>)"</endfold id='4'>;
static const char* rawString1a = u8R<beginfold id='4'>"(</beginfold id='4'>string<endfold id='4'>)"</endfold id='4'>;
static const char16_t* rawString1b = uR<beginfold id='4'>"(</beginfold id='4'>string<endfold id='4'>)"</endfold id='4'>;
static const char32_t* rawString1c = UR<beginfold id='4'>"(</beginfold id='4'>string<endfold id='4'>)"</endfold id='4'>;
static const wchar_t* rawString1d = LR<beginfold id='4'>"(</beginfold id='4'>string\nstring<endfold id='4'>)"</endfold id='4'>;
static const char* rawString2 = R<beginfold id='4'>"ab(</beginfold id='4'>string\nstring%s)ab "<endfold id='4'>)ab"</endfold id='4'>;
static const char* rawString3 = R<beginfold id='4'>"ab(</beginfold id='4'>string
string%<endfold id='4'>)ab"</endfold id='4'>;
" %d %df fd" U"ds %d" R<beginfold id='4'>"(</beginfold id='4'>a%d<endfold id='4'>)"</endfold id='4'>;
"\x{12343} \x{1} \o{12121} \u{1221a} \N{LATIN CAPITAL LETTER A WITH MACRON}"
"\x123xsk";
u"\x123xsk";
// error
u8"\x123xsk";
"\x{123x43} \o{121821} \u{12x21as} \N{LATIN CAPITAL letter A WITH MACRON}"
// printf format
"a%10sa%-10sa%*sa%-10.*sa%-*.*sa"
"a%ca%*ca%%a%ia%da%.6ia%.0ia%+ia%ia%xa%#xa"
"a%.0fa%.32fa%05.2fa%.2fa%5.2fa%Ea%aa"
// std::format
"a{{:6}}a{}a{:6}a{:*<6}a{:6d}a"
"a{0:}a{0:+}a{0:-}a{0: }a"
"a{:+06d}a{:#06x}a{:<06}a"
"a{:{}}a{0:{1}.{2}f}a"
;
// UDL (c++11)
operator""_a(const char*);
operator ""_a(const char*);
operator "" _a(const char*);
// invalid suffix
operator "" a(const char*);
operator ""a(const char*);
operator""a(const char*);
"string"_s; // user
"string"s; // standard
"string"_s-b; // -b is not part of the string
// Macro
MY_XXX;
BOOST_XXX;
__STDC_VERSION__;
__TIME__;
__cplusplus;
// Attributes
[[noreturn]] void foo();
[[deprecated]] void foo();
[[deprecated("because")]] void foo();
void foo([[carries_dependency]] int);
[[opt(1), debug]]
[[using CC: opt(1), debug]] // c++17
[[using CC: CC::opt(1)]] // c++17
[[gnu::assume_aligned(3'2l,2)]] void* f();
[[using gnu: assume_aligned(3)]]
[[clang::assume_aligned(3)]]
void f([[maybe_unused]] int val)
<beginfold id='3'>{</beginfold id='3'>
[[maybe_unused]] int x;
switch (x = foo(); x) <beginfold id='3'>{</beginfold id='3'>
case 1:
[[fallthrough]];
case XXX:
case Class::foo():
[[fallthrough]];
default:
;
<endfold id='3'>}</endfold id='3'>
// c++17: fold expression
(args + ... + (1 * 2));
(v.push_back(args), ...);
[[omp::parallel]] for (auto&& x : v)
x;
for (auto&& [first,second] : mymap) <beginfold id='3'>{</beginfold id='3'>
<endfold id='3'>}</endfold id='3'>
auto [x, y] = foo();
[x = 1, =y]()<beginfold id='3'>{</beginfold id='3'><endfold id='3'>}</endfold id='3'>;
decltype((auto)) x = foo();
<endfold id='3'>}</endfold id='3'>
auto f() -> decltype(foo());
__attribute__((pure)) void f();
label:
goto label;
<beginfold id='5'>//BEGIN</beginfold id='5'> region
// TODO comment FIXME comment ### comment BUG comment
<endfold id='5'>//END</endfold id='5'> region
// \brief blah blah
/// \brief blah blah
<beginfold id='6'>/**</beginfold id='6'>
* Doxygen
* @param p1 text
* \brief <b>bold text</b>
* <beginfold id='7'>\dot</beginfold id='7'>
* a -> b
* <endfold id='7'>\enddot</endfold id='7'>
*
* <beginfold id='7'>\verbatim</beginfold id='7'>
* <dummy>
* <endfold id='7'>\endverbatim</endfold id='7'>
* <html>text</html>
<endfold id='6'>*/</endfold id='6'>
#<endfold id='2'>endif</endfold id='2'>
// Some GNU macros, cross-referenced from gcc.xml to isocpp.xml
__GCC_ATOMIC_CHAR16_T_LOCK_FREE
__GNUC__
__linux__
// Digraphs (see bug #411508)
%:include <stdio.h>
int main()
<beginfold id='3'><%</beginfold id='3'>
[]()<beginfold id='3'>{</beginfold id='3'><endfold id='3'>%></endfold id='3'>();
<endfold id='3'>}</endfold id='3'>
<:<:fallthrough]]
<beginfold id='6'>/**</beginfold id='6'>
* multi-line comment
<endfold id='6'>*/</endfold id='6'>
<beginfold id='1'>/*</beginfold id='1'> comment <endfold id='1'>*/</endfold id='1'>
<beginfold id='3'>{</beginfold id='3'> <beginfold id='3'>{</beginfold id='3'> <endfold id='3'>}</endfold id='3'> <beginfold id='3'>{</beginfold id='3'>
<beginfold id='5'>//BEGIN</beginfold id='5'>
<endfold id='3'>}</endfold id='3'>
<endfold id='5'>//END</endfold id='5'>
<endfold id='3'>}</endfold id='3'>
#<beginfold id='2'></beginfold id='2'>if 0
<endfold id='2'></endfold id='2'><beginfold id='2'>#elif 1</beginfold id='2'>
<endfold id='2'></endfold id='2'><beginfold id='2'>#else</beginfold id='2'>
<endfold id='2'>#endif</endfold id='2'>
#<beginfold id='2'></beginfold id='2'>if 1
int x; // variable shall not be grey
<endfold id='2'>#endif</endfold id='2'>
#<beginfold id='2'></beginfold id='2'>if defined (A)
int y; // variable shall not be grey
#<endfold id='2'></endfold id='2'><beginfold id='2'></beginfold id='2'>elif defined (B)
int z; // variable shall not be grey
#<endfold id='2'>endif</endfold id='2'>
<beginfold id='6'>/*!</beginfold id='6'>
* formula <beginfold id='7'>@f$</beginfold id='7'>a+b<endfold id='7'>@f$</endfold id='7'> inside a block comment
<endfold id='6'>*/</endfold id='6'>
//! formula <beginfold id='7'>@f$</beginfold id='7'>a+b<endfold id='7'>@f$</endfold id='7'> inside a inline comment
// formula @f$a+b@f$ inside a normal comment
/// \b sa