Christian Grasser a61b03ea88 Update Scintilla from v4.4.6 to v5.2.1 and add Lexilla v5.1.5
Update with https://www.scintilla.org/scintilla521.zip
            https://www.scintilla.org/lexilla515.zip

- fix setting to bring Scintilla::PositionCR from ScintillaStructures.h inline with Sci_Position.h Sci_PositionCR
- add workaround to enable lexer for searchResult
commented out SCI_SETILEXER call on searchResult to get one result which is correctly handled by the lexer,
added comment about the current problem with property @MarkingsStruct which seems to disappear after call to SCI_SETILEXER or CreateLexer
- corrected usage of ObjC lexer
- removed unnecessary filter stuff
- use own sections for scintilla and lexilla build targets and allow parallel builds
- as libscilex is no longer existing, changed to libscintilla
- adapt makefiles and cmake
- use VS2019
- started simple changes for createlexer adaptations, nullpointercheck missing on return of lexer name from deprecated LexerNameFromID -> undefined behaviour
- movement from id -> lexer name, mostly done via LexerNameFromID + switching off corresponding compiler warning
- changed to SCI_SETILEXER from SCI_SETLEXER, SCI_SETLEXERLANGUAGE needs to be corrected, see Scintilla5Migration.html
- just commented out: SCI_LOADLEXERLIBRARY

Fix #10504, close #11419
2022-03-27 17:12:53 +02:00

55 lines
1.7 KiB
Plaintext

0 400 400 use v6;
1 400 400
0 400 400 # Normal single line comment
0 400 400 my Int $i = 0;
0 400 400 my Rat $r = 3.142;
0 400 400 my Str $s = "Hello, world! \$i == $i and \$r == $r";
0 400 400 say $s;
1 400 400
2 400 401 + #`{{
0 401 401 | *** This is a multi-line comment ***
0 401 400 | }}
1 400 400
0 400 400 my @array = #`[[ inline comment ]] <f fo foo food>;
0 400 400 my %hash = ( AAA => 1, BBB => 2 );
1 400 400
0 400 400 say q[This back\slash stays];
0 400 400 say q[This back\\slash stays]; # Identical output
0 400 400 say Q:q!Just a literal "\n" here!;
1 400 400
2 400 401 + =begin pod
0 401 401 | POD Documentation...
0 401 400 | =end pod
1 400 400
0 400 400 say qq:to/END/;
0 400 400 A multi-line
0 400 400 string with interpolated vars: $i, $r
0 400 400 END
1 400 400
2 400 401 + sub function {
0 401 401 | return q:to/END/;
0 401 401 | Here is
0 401 401 | some multi-line
0 401 401 | string
0 401 401 | END
0 401 400 | }
1 400 400
0 400 400 my $func = &function;
0 400 400 say $func();
1 400 400
2 400 401 + grammar Calculator {
0 401 401 | token TOP { <calc-op> }
0 401 401 | proto rule calc-op {*}
0 401 401 | rule calc-op:sym<add> { <num> '+' <num> }
0 401 401 | rule calc-op:sym<sub> { <num> '-' <num> }
0 401 401 | token num { \d+ }
0 401 400 | }
1 400 400
2 400 401 + class Calculations {
0 401 401 | method TOP ($/) { make $<calc-op>.made; }
0 401 401 | method calc-op:sym<add> ($/) { make [+] $<num>; }
0 401 401 | method calc-op:sym<sub> ($/) { make [-] $<num>; }
0 401 400 | }
1 400 400
0 400 400 say Calculator.parse('2 + 3', actions => Calculations).made;
0 400 0