Skip to content

Releases: andreasfertig/cppinsights

v_19.1

11 Jan 12:12
5a8071a
Compare
Choose a tag to compare

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 in typeid(type) gets replaced by const 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...
Read more

continuous

22 Jul 18:26
Compare
Choose a tag to compare

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 in typeid(type) gets replaced by const 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...
Read more

v_17.0

03 Apr 15:40
b777e0e
Compare
Choose a tag to compare

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 in typeid(type) gets replaced by const 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...
Read more

v_16.0

08 Apr 20:22
7047fbe
Compare
Choose a tag to compare

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:

  • different result from godbolt (#604)
  • crash when parse cpp file (#602)
  • std::move redundant?? (#601)
  • Build on visualstudio 2019 get ascii, utf errors (#599)
  • About the release scheme (#592)

v_0.10

02 Oct 05:39
9147b89
Compare
Choose a tag to compare

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 in typeid(type) gets replaced by const 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

03 Feb 17:17
a6dabbb
Compare
Choose a tag to compare

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:

  • Problems building on windows (#508)
  • printing output in html format!! (#505)
  • Ninja command through error. (#504)
  • Please guide the complete installation process in ubuntu (#503)
  • How to install cpp insights (#502)
  • make command issue (#498)

v_0.8

18 Jul 13:05
832460e
Compare
Choose a tag to compare

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...
Read more

v_0.7

03 Feb 16:19
2f6888e
Compare
Choose a tag to compare

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...
Read more

v_0.6

22 Apr 07:56
c984b8e
Compare
Choose a tag to compare

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...
Read more

v_0.5

05 Apr 06:40
2607267
Compare
Choose a tag to compare

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)...
Read more