Histórico de Commits

Autor SHA1 Mensagem Data
  Pierre Muller b0b60431ad Fix LLVM cycle with -O4 option. há 1 mês atrás
  Sven/Sarah Barth 155756f668 * if an outer capturer is required then that outer capturer must not be optimized into a register (fixes compilation with -Ooregvar enabled (e.g. in -O3)) há 9 meses atrás
  Alligator-1 9caabdc4e7 Immediately set the capacity há 1 ano atrás
  Sven/Sarah Barth ad61db2ff5 * allow a nested function that calls itself can be converted to a function reference há 1 ano atrás
  Sven/Sarah Barth 1853d1ddd8 * keep track which nested function definition the new method has been converted from há 1 ano atrás
  Sven/Sarah Barth 1606d4e28d * only walk the node tree if there are indeed captured symbols to convert há 1 ano atrás
  Sven/Sarah Barth ab5c5a7e9a * also keep track of captured def (necessary when functions are captured) há 1 ano atrás
  Sven/Sarah Barth b5b7cd54eb * fix typo in comment há 1 ano atrás
  Sven/Sarah Barth 787454d5b2 * correctly handle managed function results when converting a global or nested function to a function reference há 1 ano atrás
  Sven/Sarah Barth ca0323d4ca * the adjusted nested function needs to access the parent function for the capturer há 1 ano atrás
  Sven/Sarah Barth 08dca09c7e * revert 430bcac389c29a5ceca7759cfca69454aa31abf9 as with the change that the functions to insert hidden parameters are idempotent this is no longer required and also wrong as uses of the deleted symbols aside from Self and the framepointer would be left dangling há 2 anos atrás
  Sven/Sarah Barth 430bcac389 * ensure that all hidden parameter symbols are removed when adding an anonymous function to a capturer (they'll be added again later on) há 2 anos atrás
  Sven/Sarah Barth 5d7e3ca240 * fix #40060: ensure that Self is not added for anonymous functions that are part of a static class method há 2 anos atrás
  Sven/Sarah Barth 4c6338207f * fix #40061: the Self of types that aren't implicit pointers (recods, TP-style objects, primitive types (for helpers)) needs to be stored as a Pointer in the Capturer so that modifications are correctly visible há 2 anos atrás
  Sven/Sarah Barth b051e7667c * fix #39978: ensure that Self is captured when a method of the current class is captured into a function reference há 3 anos atrás
  Sven/Sarah Barth 19cee9b841 + mark the def for a capturer class with a corresponding object option há 3 anos atrás
  Sven/Sarah Barth a714e2ff35 * fix #39981: retrieve the symbol that returns the desired procdef/procvardef not maybe the Self or something else as we need that symbol to differentiate the procdefs há 3 anos atrás
  Sven/Sarah Barth b11366c95b * when generating the call to the extracted function reference inside the nested routine we need to use the parameters of the nested function and not those of the newly created procdef (fixes some of the test case failures with -O2) há 3 anos atrás
  Sven/Sarah Barth 965bba5ab4 * cleanup captured symbols when moving them from the nested function to the new method há 3 anos atrás
  Sven/Sarah Barth 4f9acc10f0 * fix #39898: when a loadnode is captured ensure that its nf_load_procvar flag is applied to the subscript node as well há 3 anos atrás
  Sven/Sarah Barth 5e7330448d * fix #39858: correctly keep track of symbols that need to be captured into the capturer há 3 anos atrás
  Sven/Sarah Barth 260368ea55 * the clause for converting the captured symbols of a nested function must not be entered by an anonymous function há 3 anos atrás
  florian 59811090e1 * captured variables cannot be in registers typically há 3 anos atrás
  Sven/Sarah Barth 8d90cd3e64 * fix #39826: correctly handle function references that are part of generics/specializations, but are not generics/specializations themselves há 3 anos atrás
  florian 98ec81896e * do not throw messages on potentially uninitialized internal symbols, resolves #39744 há 3 anos atrás
  Pierre Muller 430f1910ed Fix compliation error with -Oodfa option as reported by Gareth há 3 anos atrás
  Sven/Sarah Barth a27bc236a0 * fix #39742: when assigning a function to a function reference it's not the function itself that needs to be checked to be captureable, but instead what it captures (this applies for both the non-generic and the generic case) há 3 anos atrás
  Sven/Sarah Barth 3b7842c30e * ensure that a nested function variable can not be assigned to a function reference há 3 anos atrás
  Jonas Maebe 59f293711a function references: make names of interface methods valid Pascal identifiers há 3 anos atrás
  Sven/Sarah Barth 29cfa3b225 * ensure that the VMT for the function reference interface is generated correctly, but for this the invokedef needs to be copied without hidden parameters (and handle_calling_convention will be done by the VMT builder as well) há 3 anos atrás