Releases: andreasfertig/cppinsights
Releases · andreasfertig/cppinsights
v_19.1
Bug Fixes:
- Insight code missing ';' (#682)
- Does not handle final_suspend properly in coroutine transformation (#679)
- Generates incorrect code when variable is declared in the while loop parentheses (#678)
- Segmentation fault with
noexcept( condition )
(#654) - std::initializer_list transformation produces invalid code (#647)
- [[likely]] and [[unlikely]] delete condition bodies (#644)
- structured binding with lambda reports 'Segmentation fault' (#633)
- Segmentation Fault: Stack dump without symbol names (#628)
- NRVO translation is not NRVO eligible (#620)
- explicit casting for const (#610)
- Superfluous parentheses in declarations are handled incorrectly (#606)
- Incorrect move-only lambda code generation (#605)
- Add support for
SourceLocExpr
(#598) - Class template argument deduction not working - cpp17 (#596)
- Pack expansion in ctor call transformed into invalid c++ (#595)
- Errors in transforming "int& a = A()" (#593)
- Errors in transforming
struct T {} var
(#588) - Specialization of variable templates misses type deduction and
template
(#556) - About nested class inside a class template (#555)
- Error building inside clang source tree (#554)
- invoke lambda with
temp.operator()()
generate wrong code. (#550) - Generated insight for
jmp_buf
global variable declarations. (#543) - [BUG] with getting a global variable (#540)
- coroutine transformation: Support promise-constructor-arguments (#536)
- for-loops as while-loops is wrong for ranged-based for loop (#528)
- CppInsights crash with stack dump (#526)
- The
type
intypeid(type)
gets replaced byconst std::type_info
(#522) - cppinsights crash with stack dump (#520)
- cpp coro recursively task "coroutine transformation" wrong (#518)
- static_cast instead of reinterpret_cast for interpreting pointer to integral conversion (#512)
inline namespace
in global scope causes crash (#509)- Wrong output for the initialization of static variables within a function (#507)
- Incorrect naming in parameter pack expansion (#506)
- Function template arguments are not shown (#501)
- Declaration of multiple variables is handled incorrectly (#500)
- [C++20] Lambdas in unevaluated contexts: wrong conversion from lambda to std::priority_queue (#492)
- Lambda decay inside lambda capture puts class definition inside constructor arguments (#491)
- Odd output for decltype return values. Lambda hunt. (#490)
- wrong name of base class (#473)
- C++20 lambda in unevaluated context not shown (#468)
- static inside lambda results in incorrect code (#467)
- convert ‘bool’ to ‘clang::TemplateName::Qualified’not allowed in latest GCC (#458)
- alignas(xxx) is repeated (#456)
- overloading operator new and operator delete (#455)
- noexcept for member functions not generating try...catch (#454)
- Incorrect templated static member variable initialization (#427)
- Structured bindings with pair/tuple not producing references (#425)
- Conversion-operator not shown within argument for function template (#415)
- Explicit instantiation definitions for class templates generate double definitions (#411)
- Bugged output for namespace variable declaration (#408)
- Missing implicit cast for compound operator (#405)
- Array bounds are mirrored if remove_all_extents_t<array_type> is instantiated from a template (#404)
- Initializations with a lambda inside lambda capture (#402)
- This is a bug. Or should it be? (#400)
- Incorrectly interprets C cast as static_cast instead of reinterpret_cast (#398)
- Incorrect code generated for final template specialisations (#391)
- the decltype result is not complete (#389)
- Incorrect code generation for IIFE inside if without parentheses (#386)
- structured binding - wrong value category passed to the get function. (#381)
- Lambda capture in a member function (#379)
- macros "inside" enums are not expanded (#377)
- Complex macros are not expanded (#376)
- Inside a class body, pointers to members of the class are turned into ordinary pointers (#374)
- Program does not compile when using LLVM 11. (#371)
- initializing static variables (#369)
- Incorrect output for template code (#365)
- Duplication of attribute specifier (#354)
- Invalid array member type with structured bindings (#352)
- Incorrect constructor in return statement (#351)
- Incorrect alias type naming of aliases for pointer to member types (#349)
- Lambda constructor shows uneccesary copies (#347)
- A minor attention to lambda expressions (#344)
- Reference to type alias denoting an array type is mishandled in function return type (#341)
- Doesn't show const qualification when using decltype (#337)
- Example from cppreference compiles on godbolt, doesn't compile in insights (#333)
- Incorrect macro expansions (#331)
- std::is_same_v<> produces wrong insight (#328)
- Imprecise translation for ternary operator (#324)
- wrong variadic template expansion (#323)
- C++ Insights - Episode 1: The invisible things - Invalid ImplicitCast (#313)
- Cppinsights loses alignas specifications (#311)
- Call of
template <typename T> void fun (T&& t) { };
leads to segfault (#298) - Anonymous struct shouldn't be named as `(anonymous...
continuous
Bug Fixes:
- Insight code missing ';' (#682)
- Does not handle final_suspend properly in coroutine transformation (#679)
- Generates incorrect code when variable is declared in the while loop parentheses (#678)
- Segmentation fault with
noexcept( condition )
(#654) - std::initializer_list transformation produces invalid code (#647)
- [[likely]] and [[unlikely]] delete condition bodies (#644)
- structured binding with lambda reports 'Segmentation fault' (#633)
- Segmentation Fault: Stack dump without symbol names (#628)
- NRVO translation is not NRVO eligible (#620)
- explicit casting for const (#610)
- Superfluous parentheses in declarations are handled incorrectly (#606)
- Incorrect move-only lambda code generation (#605)
- Add support for
SourceLocExpr
(#598) - Class template argument deduction not working - cpp17 (#596)
- Pack expansion in ctor call transformed into invalid c++ (#595)
- Errors in transforming "int& a = A()" (#593)
- Errors in transforming
struct T {} var
(#588) - Specialization of variable templates misses type deduction and
template
(#556) - About nested class inside a class template (#555)
- Error building inside clang source tree (#554)
- invoke lambda with
temp.operator()()
generate wrong code. (#550) - Generated insight for
jmp_buf
global variable declarations. (#543) - [BUG] with getting a global variable (#540)
- coroutine transformation: Support promise-constructor-arguments (#536)
- for-loops as while-loops is wrong for ranged-based for loop (#528)
- CppInsights crash with stack dump (#526)
- The
type
intypeid(type)
gets replaced byconst std::type_info
(#522) - cppinsights crash with stack dump (#520)
- cpp coro recursively task "coroutine transformation" wrong (#518)
- static_cast instead of reinterpret_cast for interpreting pointer to integral conversion (#512)
inline namespace
in global scope causes crash (#509)- Wrong output for the initialization of static variables within a function (#507)
- Incorrect naming in parameter pack expansion (#506)
- Function template arguments are not shown (#501)
- Declaration of multiple variables is handled incorrectly (#500)
- [C++20] Lambdas in unevaluated contexts: wrong conversion from lambda to std::priority_queue (#492)
- Lambda decay inside lambda capture puts class definition inside constructor arguments (#491)
- Odd output for decltype return values. Lambda hunt. (#490)
- wrong name of base class (#473)
- C++20 lambda in unevaluated context not shown (#468)
- static inside lambda results in incorrect code (#467)
- convert ‘bool’ to ‘clang::TemplateName::Qualified’not allowed in latest GCC (#458)
- alignas(xxx) is repeated (#456)
- overloading operator new and operator delete (#455)
- noexcept for member functions not generating try...catch (#454)
- Incorrect templated static member variable initialization (#427)
- Structured bindings with pair/tuple not producing references (#425)
- Conversion-operator not shown within argument for function template (#415)
- Explicit instantiation definitions for class templates generate double definitions (#411)
- Bugged output for namespace variable declaration (#408)
- Missing implicit cast for compound operator (#405)
- Array bounds are mirrored if remove_all_extents_t<array_type> is instantiated from a template (#404)
- Initializations with a lambda inside lambda capture (#402)
- This is a bug. Or should it be? (#400)
- Incorrectly interprets C cast as static_cast instead of reinterpret_cast (#398)
- Incorrect code generated for final template specialisations (#391)
- the decltype result is not complete (#389)
- Incorrect code generation for IIFE inside if without parentheses (#386)
- structured binding - wrong value category passed to the get function. (#381)
- Lambda capture in a member function (#379)
- macros "inside" enums are not expanded (#377)
- Complex macros are not expanded (#376)
- Inside a class body, pointers to members of the class are turned into ordinary pointers (#374)
- Program does not compile when using LLVM 11. (#371)
- initializing static variables (#369)
- Incorrect output for template code (#365)
- Duplication of attribute specifier (#354)
- Invalid array member type with structured bindings (#352)
- Incorrect constructor in return statement (#351)
- Incorrect alias type naming of aliases for pointer to member types (#349)
- Lambda constructor shows uneccesary copies (#347)
- A minor attention to lambda expressions (#344)
- Reference to type alias denoting an array type is mishandled in function return type (#341)
- Doesn't show const qualification when using decltype (#337)
- Example from cppreference compiles on godbolt, doesn't compile in insights (#333)
- Incorrect macro expansions (#331)
- std::is_same_v<> produces wrong insight (#328)
- Imprecise translation for ternary operator (#324)
- wrong variadic template expansion (#323)
- C++ Insights - Episode 1: The invisible things - Invalid ImplicitCast (#313)
- Cppinsights loses alignas specifications (#311)
- Call of
template <typename T> void fun (T&& t) { };
leads to segfault (#298) - Anonymous struct shouldn't be named as `(anonymous...
v_17.0
Bug Fixes:
- NRVO translation is not NRVO eligible (#620)
- explicit casting for const (#610)
- Superfluous parentheses in declarations are handled incorrectly (#606)
- Incorrect move-only lambda code generation (#605)
- Add support for
SourceLocExpr
(#598) - Class template argument deduction not working - cpp17 (#596)
- Errors in transforming "int& a = A()" (#593)
- Errors in transforming
struct T {} var
(#588) - Specialization of variable templates misses type deduction and
template
(#556) - About nested class inside a class template (#555)
- Error building inside clang source tree (#554)
- invoke lambda with
temp.operator()()
generate wrong code. (#550) - Generated insight for
jmp_buf
global variable declarations. (#543) - [BUG] with getting a global variable (#540)
- coroutine transformation: Support promise-constructor-arguments (#536)
- for-loops as while-loops is wrong for ranged-based for loop (#528)
- CppInsights crash with stack dump (#526)
- The
type
intypeid(type)
gets replaced byconst std::type_info
(#522) - cppinsights crash with stack dump (#520)
- cpp coro recursively task "coroutine transformation" wrong (#518)
- static_cast instead of reinterpret_cast for interpreting pointer to integral conversion (#512)
inline namespace
in global scope causes crash (#509)- Wrong output for the initialization of static variables within a function (#507)
- Incorrect naming in parameter pack expansion (#506)
- Function template arguments are not shown (#501)
- Declaration of multiple variables is handled incorrectly (#500)
- [C++20] Lambdas in unevaluated contexts: wrong conversion from lambda to std::priority_queue (#492)
- Lambda decay inside lambda capture puts class definition inside constructor arguments (#491)
- Odd output for decltype return values. Lambda hunt. (#490)
- wrong name of base class (#473)
- C++20 lambda in unevaluated context not shown (#468)
- static inside lambda results in incorrect code (#467)
- convert ‘bool’ to ‘clang::TemplateName::Qualified’not allowed in latest GCC (#458)
- alignas(xxx) is repeated (#456)
- overloading operator new and operator delete (#455)
- noexcept for member functions not generating try...catch (#454)
- Incorrect templated static member variable initialization (#427)
- Structured bindings with pair/tuple not producing references (#425)
- Conversion-operator not shown within argument for function template (#415)
- Explicit instantiation definitions for class templates generate double definitions (#411)
- Bugged output for namespace variable declaration (#408)
- Missing implicit cast for compound operator (#405)
- Array bounds are mirrored if remove_all_extents_t<array_type> is instantiated from a template (#404)
- Initializations with a lambda inside lambda capture (#402)
- This is a bug. Or should it be? (#400)
- Incorrectly interprets C cast as static_cast instead of reinterpret_cast (#398)
- Incorrect code generated for final template specialisations (#391)
- the decltype result is not complete (#389)
- Incorrect code generation for IIFE inside if without parentheses (#386)
- structured binding - wrong value category passed to the get function. (#381)
- Lambda capture in a member function (#379)
- macros "inside" enums are not expanded (#377)
- Complex macros are not expanded (#376)
- Inside a class body, pointers to members of the class are turned into ordinary pointers (#374)
- Program does not compile when using LLVM 11. (#371)
- initializing static variables (#369)
- Incorrect output for template code (#365)
- Duplication of attribute specifier (#354)
- Invalid array member type with structured bindings (#352)
- Incorrect constructor in return statement (#351)
- Incorrect alias type naming of aliases for pointer to member types (#349)
- Lambda constructor shows uneccesary copies (#347)
- A minor attention to lambda expressions (#344)
- Reference to type alias denoting an array type is mishandled in function return type (#341)
- Doesn't show const qualification when using decltype (#337)
- Example from cppreference compiles on godbolt, doesn't compile in insights (#333)
- Incorrect macro expansions (#331)
- std::is_same_v<> produces wrong insight (#328)
- Imprecise translation for ternary operator (#324)
- wrong variadic template expansion (#323)
- C++ Insights - Episode 1: The invisible things - Invalid ImplicitCast (#313)
- Cppinsights loses alignas specifications (#311)
- Call of
template <typename T> void fun (T&& t) { };
leads to segfault (#298) - Anonymous struct shouldn't be named as
(anonymous)
(#290) - Segmentation fault? (#288)
decltype
isn't resolved when followed by&
(#286)- ConstexprVariableCase duplicated in clang-tidy options file (#280)
- The name of a variable of type "pointer to member" is misplaced (#279)
- Folding expressions missing parenthesis (#264)
- C++14 lambda with init capture does not generate valid code (#258)
- ranged for-loop inside lambda crashes (#238)
- Virtual inheritance is lost (#236)
- Add a limitation respect to the generated =deleted speci...
v_16.0
Bug Fixes:
- Segmentation Fault: Stack dump without symbol names (#628)
- NRVO translation is not NRVO eligible (#620)
- explicit casting for const (#610)
- Superfluous parentheses in declarations are handled incorrectly (#606)
- Incorrect move-only lambda code generation (#605)
- Add support for
SourceLocExpr
(#598) - Class template argument deduction not working - cpp17 (#596)
- Errors in transforming "int& a = A()" (#593)
- Errors in transforming
struct T {} var
(#588) - Wrong output for the initialization of static variables within a function (#507)
- Declaration of multiple variables is handled incorrectly (#500)
- Complex macros are not expanded (#376)
Closed:
v_0.10
Bug Fixes:
- Specialization of variable templates misses type deduction and
template
(#556) - About nested class inside a class template (#555)
- Error building inside clang source tree (#554)
- invoke lambda with
temp.operator()()
generate wrong code. (#550) - Generated insight for
jmp_buf
global variable declarations. (#543) - [BUG] with getting a global variable (#540)
- coroutine transformation: Support promise-constructor-arguments (#536)
- for-loops as while-loops is wrong for ranged-based for loop (#528)
- CppInsights crash with stack dump (#526)
- The
type
intypeid(type)
gets replaced byconst std::type_info
(#522) - cppinsights crash with stack dump (#520)
- cpp coro recursively task "coroutine transformation" wrong (#518)
- Incorrect naming in parameter pack expansion (#506)
- Function template arguments are not shown (#501)
- [C++20] Lambdas in unevaluated contexts: wrong conversion from lambda to std::priority_queue (#492)
- Lambda decay inside lambda capture puts class definition inside constructor arguments (#491)
Enhancements:
- Missing Clang 16 support (#525)
- [C++20] format header file is not found (#470)
- Feature request: show substitution failures (#423)
- Can insights show the relationship info between source's lines and the output's line? (#393)
- New Feature Offering: Compilers versions comparation (#345)
- Support Boost headers (#263)
- Synchronize scrolling in the web version (#8)
Closed:
- cppinsights.io doesn't show the what is listed in github.com (#570)
- Site is down (#564)
- Can I use #include <Windows.h> with cppinsights? (#535)
- [BUG] Code Example Doesn't Compile (#524)
- Stack dump without symbol names (ensure you have llvm-symbolizer in your PATH or set the environment var
LLVM_SYMBOLIZER_PATH
to point to it) (#519) - [document] Vim plugin for cppinsights (#516)
- [C++20] Coroutine header file requires -fcoroutines (#469)
- Add example for : destructors are implicitly noexcept (#225)
v_0.9
Bug Fixes:
- static_cast instead of reinterpret_cast for interpreting pointer to integral conversion (#512)
inline namespace
in global scope causes crash (#509)- Odd output for decltype return values. Lambda hunt. (#490)
- C++20 lambda in unevaluated context not shown (#468)
- Conversion-operator not shown within argument for function template (#415)
- A minor attention to lambda expressions (#344)
Closed:
v_0.8
Bug Fixes:
- wrong name of base class (#473)
- C++20 lambda in unevaluated context not shown (#468)
- static inside lambda results in incorrect code (#467)
- convert ‘bool’ to ‘clang::TemplateName::Qualified’not allowed in latest GCC (#458)
- alignas(xxx) is repeated (#456)
- overloading operator new and operator delete (#455)
- noexcept for member functions not generating try...catch (#454)
- Incorrect templated static member variable initialization (#427)
- Structured bindings with pair/tuple not producing references (#425)
- Conversion-operator not shown within argument for function template (#415)
- Explicit instantiation definitions for class templates generate double definitions (#411)
- Bugged output for namespace variable declaration (#408)
- Missing implicit cast for compound operator (#405)
- Array bounds are mirrored if remove_all_extents_t<array_type> is instantiated from a template (#404)
- Initializations with a lambda inside lambda capture (#402)
- This is a bug. Or should it be? (#400)
- Incorrectly interprets C cast as static_cast instead of reinterpret_cast (#398)
- Incorrect code generated for final template specialisations (#391)
- the decltype result is not complete (#389)
- Incorrect code generation for IIFE inside if without parentheses (#386)
- structured binding - wrong value category passed to the get function. (#381)
- Lambda capture in a member function (#379)
- macros "inside" enums are not expanded (#377)
- Inside a class body, pointers to members of the class are turned into ordinary pointers (#374)
- Program does not compile when using LLVM 11. (#371)
- initializing static variables (#369)
- Incorrect output for template code (#365)
- Duplication of attribute specifier (#354)
- Invalid array member type with structured bindings (#352)
- Incorrect constructor in return statement (#351)
- Incorrect alias type naming of aliases for pointer to member types (#349)
- Lambda constructor shows uneccesary copies (#347)
- A minor attention to lambda expressions (#344)
- Reference to type alias denoting an array type is mishandled in function return type (#341)
- Doesn't show const qualification when using decltype (#337)
- Example from cppreference compiles on godbolt, doesn't compile in insights (#333)
- Incorrect macro expansions (#331)
- std::is_same_v<> produces wrong insight (#328)
- Imprecise translation for ternary operator (#324)
- wrong variadic template expansion (#323)
- C++ Insights - Episode 1: The invisible things - Invalid ImplicitCast (#313)
- Cppinsights loses alignas specifications (#311)
- Call of
template <typename T> void fun (T&& t) { };
leads to segfault (#298) - Anonymous struct shouldn't be named as
(anonymous)
(#290) - Segmentation fault? (#288)
decltype
isn't resolved when followed by&
(#286)- ConstexprVariableCase duplicated in clang-tidy options file (#280)
- The name of a variable of type "pointer to member" is misplaced (#279)
- Folding expressions missing parenthesis (#264)
- C++14 lambda with init capture does not generate valid code (#258)
- ranged for-loop inside lambda crashes (#238)
- Virtual inheritance is lost (#236)
- Add a limitation respect to the generated =deleted special operations (#233)
- bitfields transformation miss the bitfield size (#227)
- Direct initialization of built-in type produce extra ");" (#217)
- Crash on https://cppinsights.io when trying code with member variables of type std::function<void()> and assigning it with lambda expression (#205)
- volatile qualifier is moved from member function to its return type (#201)
- cppinsights loses
template<>
in explicit function template specializations (#200) - Trailing comma in template-parameter-list when TemplateArgument pack is empty (#199)
- support expand macro (#193)
- Crash with stack trace, trying to get insight about std::tuple (#188)
- Inheritance from variadic list not expanded well (#184)
- function pointer argument name removed (#182)
- Closure object structured binding: data member names are missing (#181)
- Boby of one-liner ranged-based for discarded (#161)
- artifacts }; remain for N3922 declarations (#158)
- Structure binding a tuple-like type (#131)
- Ellipsis missing from template instatiation (#128)
- Incorrect type of a function returning a rvalue reference to a function or array (#124)
- unexpected behavior when explicitly instantiating a template (#123)
- Missed const qualifier in structured binding (#116)
- usingShadow unsued variable (#112)
- Insight is screwed for top-level variables with type placeholder and an array new expression initializers (#108)
- Dimensions swapped in new expression with multidimension array (#106)
- class/fun templates + decltype/decltype(auto) + one screen program = CRASH (#102)
- in-tree build not working (#96)
- Folding expressions missing parenthesis (#91)
- Incorrect return type of a function returning a pointer to an array (#81)
- limits.h header isn't in include path (#78)
- Incorrect type of a function returning a reference to an array (#74)
- Lambda Capture by value for reference typed variables. (#64)
- Using pointer to member as a templ...
v_0.7
Bug Fixes:
- wrong name of base class (#473)
- static inside lambda results in incorrect code (#467)
- convert ‘bool’ to ‘clang::TemplateName::Qualified’not allowed in latest GCC (#458)
- alignas(xxx) is repeated (#456)
- overloading operator new and operator delete (#455)
- noexcept for member functions not generating try...catch (#454)
- Incorrect templated static member variable initialization (#427)
- Structured bindings with pair/tuple not producing references (#425)
- Explicit instantiation definitions for class templates generate double definitions (#411)
- Bugged output for namespace variable declaration (#408)
- Missing implicit cast for compound operator (#405)
- Array bounds are mirrored if remove_all_extents_t<array_type> is instantiated from a template (#404)
- Initializations with a lambda inside lambda capture (#402)
- This is a bug. Or should it be? (#400)
- Incorrectly interprets C cast as static_cast instead of reinterpret_cast (#398)
- Incorrect code generated for final template specialisations (#391)
- the decltype result is not complete (#389)
- Incorrect code generation for IIFE inside if without parentheses (#386)
- structured binding - wrong value category passed to the get function. (#381)
- Lambda capture in a member function (#379)
- macros "inside" enums are not expanded (#377)
- Inside a class body, pointers to members of the class are turned into ordinary pointers (#374)
- Program does not compile when using LLVM 11. (#371)
- initializing static variables (#369)
- Incorrect output for template code (#365)
- Duplication of attribute specifier (#354)
- Invalid array member type with structured bindings (#352)
- Incorrect constructor in return statement (#351)
- Incorrect alias type naming of aliases for pointer to member types (#349)
- Lambda constructor shows uneccesary copies (#347)
- Reference to type alias denoting an array type is mishandled in function return type (#341)
- Doesn't show const qualification when using decltype (#337)
- Example from cppreference compiles on godbolt, doesn't compile in insights (#333)
- Incorrect macro expansions (#331)
- std::is_same_v<> produces wrong insight (#328)
- Imprecise translation for ternary operator (#324)
- wrong variadic template expansion (#323)
- C++ Insights - Episode 1: The invisible things - Invalid ImplicitCast (#313)
- Cppinsights loses alignas specifications (#311)
- Call of
template <typename T> void fun (T&& t) { };
leads to segfault (#298) - Anonymous struct shouldn't be named as
(anonymous)
(#290) - Segmentation fault? (#288)
decltype
isn't resolved when followed by&
(#286)- ConstexprVariableCase duplicated in clang-tidy options file (#280)
- The name of a variable of type "pointer to member" is misplaced (#279)
- Folding expressions missing parenthesis (#264)
- C++14 lambda with init capture does not generate valid code (#258)
- ranged for-loop inside lambda crashes (#238)
- Virtual inheritance is lost (#236)
- Add a limitation respect to the generated =deleted special operations (#233)
- bitfields transformation miss the bitfield size (#227)
- Direct initialization of built-in type produce extra ");" (#217)
- Crash on https://cppinsights.io when trying code with member variables of type std::function<void()> and assigning it with lambda expression (#205)
- volatile qualifier is moved from member function to its return type (#201)
- cppinsights loses
template<>
in explicit function template specializations (#200) - Trailing comma in template-parameter-list when TemplateArgument pack is empty (#199)
- support expand macro (#193)
- Crash with stack trace, trying to get insight about std::tuple (#188)
- Inheritance from variadic list not expanded well (#184)
- function pointer argument name removed (#182)
- Closure object structured binding: data member names are missing (#181)
- Boby of one-liner ranged-based for discarded (#161)
- artifacts }; remain for N3922 declarations (#158)
- Structure binding a tuple-like type (#131)
- Ellipsis missing from template instatiation (#128)
- Incorrect type of a function returning a rvalue reference to a function or array (#124)
- unexpected behavior when explicitly instantiating a template (#123)
- Missed const qualifier in structured binding (#116)
- usingShadow unsued variable (#112)
- Insight is screwed for top-level variables with type placeholder and an array new expression initializers (#108)
- Dimensions swapped in new expression with multidimension array (#106)
- class/fun templates + decltype/decltype(auto) + one screen program = CRASH (#102)
- in-tree build not working (#96)
- Folding expressions missing parenthesis (#91)
- Incorrect return type of a function returning a pointer to an array (#81)
- limits.h header isn't in include path (#78)
- Incorrect type of a function returning a reference to an array (#74)
- Lambda Capture by value for reference typed variables. (#64)
- Using pointer to member as a template argument is converted to the type of the member (#60)
- Incorrect output when special member function is default (#53)
- Reference collapsing works wrong (#50)
- Expansion of globa...
v_0.6
Bug Fixes:
- Incorrect templated static member variable initialization (#427)
- Explicit instantiation definitions for class templates generate double definitions (#411)
- Bugged output for namespace variable declaration (#408)
- Initializations with a lambda inside lambda capture (#402)
- This is a bug. Or should it be? (#400)
- Incorrectly interprets C cast as static_cast instead of reinterpret_cast (#398)
- Incorrect code generated for final template specialisations (#391)
- the decltype result is not complete (#389)
- Incorrect code generation for IIFE inside if without parentheses (#386)
- structured binding - wrong value category passed to the get function. (#381)
- Lambda capture in a member function (#379)
- macros "inside" enums are not expanded (#377)
- Inside a class body, pointers to members of the class are turned into ordinary pointers (#374)
- Program does not compile when using LLVM 11. (#371)
- initializing static variables (#369)
- Incorrect output for template code (#365)
- Duplication of attribute specifier (#354)
- Invalid array member type with structured bindings (#352)
- Incorrect constructor in return statement (#351)
- Incorrect alias type naming of aliases for pointer to member types (#349)
- Lambda constructor shows uneccesary copies (#347)
- Reference to type alias denoting an array type is mishandled in function return type (#341)
- Doesn't show const qualification when using decltype (#337)
- Example from cppreference compiles on godbolt, doesn't compile in insights (#333)
- Incorrect macro expansions (#331)
- std::is_same_v<> produces wrong insight (#328)
- Imprecise translation for ternary operator (#324)
- wrong variadic template expansion (#323)
- C++ Insights - Episode 1: The invisible things - Invalid ImplicitCast (#313)
- Cppinsights loses alignas specifications (#311)
- Call of
template <typename T> void fun (T&& t) { };
leads to segfault (#298) - Anonymous struct shouldn't be named as
(anonymous)
(#290) - Segmentation fault? (#288)
decltype
isn't resolved when followed by&
(#286)- ConstexprVariableCase duplicated in clang-tidy options file (#280)
- The name of a variable of type "pointer to member" is misplaced (#279)
- Folding expressions missing parenthesis (#264)
- C++14 lambda with init capture does not generate valid code (#258)
- ranged for-loop inside lambda crashes (#238)
- Virtual inheritance is lost (#236)
- Add a limitation respect to the generated =deleted special operations (#233)
- bitfields transformation miss the bitfield size (#227)
- Direct initialization of built-in type produce extra ");" (#217)
- Crash on https://cppinsights.io when trying code with member variables of type std::function<void()> and assigning it with lambda expression (#205)
- volatile qualifier is moved from member function to its return type (#201)
- cppinsights loses
template<>
in explicit function template specializations (#200) - Trailing comma in template-parameter-list when TemplateArgument pack is empty (#199)
- support expand macro (#193)
- Crash with stack trace, trying to get insight about std::tuple (#188)
- Inheritance from variadic list not expanded well (#184)
- function pointer argument name removed (#182)
- Closure object structured binding: data member names are missing (#181)
- Boby of one-liner ranged-based for discarded (#161)
- artifacts }; remain for N3922 declarations (#158)
- Structure binding a tuple-like type (#131)
- Ellipsis missing from template instatiation (#128)
- Incorrect type of a function returning a rvalue reference to a function or array (#124)
- unexpected behavior when explicitly instantiating a template (#123)
- Missed const qualifier in structured binding (#116)
- usingShadow unsued variable (#112)
- Insight is screwed for top-level variables with type placeholder and an array new expression initializers (#108)
- Dimensions swapped in new expression with multidimension array (#106)
- class/fun templates + decltype/decltype(auto) + one screen program = CRASH (#102)
- in-tree build not working (#96)
- Folding expressions missing parenthesis (#91)
- Incorrect return type of a function returning a pointer to an array (#81)
- limits.h header isn't in include path (#78)
- Incorrect type of a function returning a reference to an array (#74)
- Lambda Capture by value for reference typed variables. (#64)
- Using pointer to member as a template argument is converted to the type of the member (#60)
- Incorrect output when special member function is default (#53)
- Reference collapsing works wrong (#50)
- Expansion of global lambda expressions is broken (#46)
- Segmentation fault when using polymorphic lambdas (#41)
- Brokenness for custom string literals (#28)
- Casting in class error (#24)
- Nonexistent variable used, with unbalanced parentheses (#20)
- Argument is missed in case chrono_literals (#15)
- Incorrect insight to const auto& (#13)
- Nested lambdas yield broken tokens (#3)
- Lambda capture with renamed variables is wrongly instantiated (#2)
Enhancements:
- spell out overload resolution (#292)
- Emi...
v_0.5
Bug Fixes:
- structured binding - wrong value category passed to the get function. (#381)
- Lambda capture in a member function (#379)
- macros "inside" enums are not expanded (#377)
- Inside a class body, pointers to members of the class are turned into ordinary pointers (#374)
- Program does not compile when using LLVM 11. (#371)
- initializing static variables (#369)
- Incorrect output for template code (#365)
- Duplication of attribute specifier (#354)
- Invalid array member type with structured bindings (#352)
- Incorrect alias type naming of aliases for pointer to member types (#349)
- Lambda constructor shows uneccesary copies (#347)
- Reference to type alias denoting an array type is mishandled in function return type (#341)
- Doesn't show const qualification when using decltype (#337)
- Example from cppreference compiles on godbolt, doesn't compile in insights (#333)
- Incorrect macro expansions (#331)
- std::is_same_v<> produces wrong insight (#328)
- Imprecise translation for ternary operator (#324)
- wrong variadic template expansion (#323)
- C++ Insights - Episode 1: The invisible things - Invalid ImplicitCast (#313)
- Cppinsights loses alignas specifications (#311)
- Call of
template <typename T> void fun (T&& t) { };
leads to segfault (#298) - Anonymous struct shouldn't be named as
(anonymous)
(#290) - Segmentation fault? (#288)
decltype
isn't resolved when followed by&
(#286)- ConstexprVariableCase duplicated in clang-tidy options file (#280)
- The name of a variable of type "pointer to member" is misplaced (#279)
- Folding expressions missing parenthesis (#264)
- C++14 lambda with init capture does not generate valid code (#258)
- ranged for-loop inside lambda crashes (#238)
- Virtual inheritance is lost (#236)
- Add a limitation respect to the generated =deleted special operations (#233)
- bitfields transformation miss the bitfield size (#227)
- Direct initialization of built-in type produce extra ");" (#217)
- Crash on https://cppinsights.io when trying code with member variables of type std::function<void()> and assigning it with lambda expression (#205)
- volatile qualifier is moved from member function to its return type (#201)
- cppinsights loses
template<>
in explicit function template specializations (#200) - Trailing comma in template-parameter-list when TemplateArgument pack is empty (#199)
- support expand macro (#193)
- Crash with stack trace, trying to get insight about std::tuple (#188)
- Inheritance from variadic list not expanded well (#184)
- function pointer argument name removed (#182)
- Closure object structured binding: data member names are missing (#181)
- Boby of one-liner ranged-based for discarded (#161)
- artifacts }; remain for N3922 declarations (#158)
- Structure binding a tuple-like type (#131)
- Ellipsis missing from template instatiation (#128)
- Incorrect type of a function returning a rvalue reference to a function or array (#124)
- unexpected behavior when explicitly instantiating a template (#123)
- Missed const qualifier in structured binding (#116)
- usingShadow unsued variable (#112)
- Insight is screwed for top-level variables with type placeholder and an array new expression initializers (#108)
- Dimensions swapped in new expression with multidimension array (#106)
- class/fun templates + decltype/decltype(auto) + one screen program = CRASH (#102)
- in-tree build not working (#96)
- Folding expressions missing parenthesis (#91)
- Incorrect return type of a function returning a pointer to an array (#81)
- limits.h header isn't in include path (#78)
- Incorrect type of a function returning a reference to an array (#74)
- Lambda Capture by value for reference typed variables. (#64)
- Using pointer to member as a template argument is converted to the type of the member (#60)
- Incorrect output when special member function is default (#53)
- Reference collapsing works wrong (#50)
- Expansion of global lambda expressions is broken (#46)
- Segmentation fault when using polymorphic lambdas (#41)
- Brokenness for custom string literals (#28)
- Casting in class error (#24)
- Nonexistent variable used, with unbalanced parentheses (#20)
- Argument is missed in case chrono_literals (#15)
- Incorrect insight to const auto& (#13)
- Nested lambdas yield broken tokens (#3)
- Lambda capture with renamed variables is wrongly instantiated (#2)
Enhancements:
- spell out overload resolution (#292)
- Emit code to see Rule of 3/5/0 (#291)
- Structured bindings with tuple shows incorrect tuple_element usage (#277)
- resolved type names for types defined in class bodies lack their "namespace" (#255)
- template arguments for templated methods don't appear in cppinsights (#254)
- Transformations around
noexcept
are minorly confusing (#251) - implicit cast after explicit cast (#223)
- Run insights on client-side with web assembly (#221)
- Adding build support for Windows (#190)
- range-v3 support (#179)
- spell out using declaration (#178)
- template lambda not compiling (#176)...