diff --git a/RELEASE-NOTES b/RELEASE-NOTES index e7da875..e05866b 100644 --- a/RELEASE-NOTES +++ b/RELEASE-NOTES @@ -25,11 +25,17 @@ - `s:split/string` replaces `s:split-on-string` - `s:split/char` replaces `s:split` +- `s:contains/char?` replaces `s:contains-char?` +- `s:contains/string?` replaces `s:contains-string?` +- `a:contains/string?` replaces `a:contains-string?` ## Deprecated - `s:split-on-string` - `s:split` +- `s:contains-char?` +- `s:contains-string?` +- `a:contains-string?` ## Hooks diff --git a/doc/Glossary-Concise.txt b/doc/Glossary-Concise.txt index 652409b..79ebdfc 100644 --- a/doc/Glossary-Concise.txt +++ b/doc/Glossary-Concise.txt @@ -233,6 +233,9 @@ a:chop D: a-a A: - F: - Return a new array containing all but the last value in the source array. a:contains-string? D: sa-f A: - F: - +Deprecated. Use `a:contains/string?` instead. Return `TRUE` if the string value is in the array or `FALSE` otherwise. + +a:contains/string? D: sa-f A: - F: - Return `TRUE` if the string value is in the array or `FALSE` otherwise. a:contains? D: na-f A: - F: - @@ -1157,9 +1160,15 @@ s:const D: ss- A: - F: - Create a constant named s2, returning a pointer to s1. This will use `s:keep` to preserve the original string. s:contains-char? D: sc-f A: - F: - -Return `TRUE` if the character is present in the string or `FALSE` otherwise. +Deprecated. Use `s:contains/char?` instead. Return `TRUE` if the character is present in the string or `FALSE` otherwise. s:contains-string? D: ss-f A: - F: - +Deprecated. Use `s:contains/string?` instead. Return `TRUE` if the second string is present in the first string or `FALSE` otherwise. + +s:contains/char? D: sc-f A: - F: - +Return `TRUE` if the character is present in the string or `FALSE` otherwise. + +s:contains/string? D: ss-f A: - F: - Return `TRUE` if the second string is present in the first string or `FALSE` otherwise. s:copy D: sa- A: - F: - diff --git a/doc/Glossary-Names-and-Stack.txt b/doc/Glossary-Names-and-Stack.txt index 45456a4..72cbc2c 100644 --- a/doc/Glossary-Names-and-Stack.txt +++ b/doc/Glossary-Names-and-Stack.txt @@ -77,6 +77,7 @@ a:append D: aa-a A: - F: - a:begins-with? D: aa-f A: - F: - a:chop D: a-a A: - F: - a:contains-string? D: sa-f A: - F: - +a:contains/string? D: sa-f A: - F: - a:contains? D: na-f A: - F: - a:copy D: aa- A: - F: - a:counted-results D: q-a A: - F: - @@ -386,6 +387,8 @@ s:chop D: s-s A: - F: - s:const D: ss- A: - F: - s:contains-char? D: sc-f A: - F: - s:contains-string? D: ss-f A: - F: - +s:contains/char? D: sc-f A: - F: - +s:contains/string? D: ss-f A: - F: - s:copy D: sa- A: - F: - s:empty D: -s A: - F: - s:ends-with? D: ss-f A: - F: - diff --git a/doc/Glossary.html b/doc/Glossary.html index a487796..f8f98ca 100644 --- a/doc/Glossary.html +++ b/doc/Glossary.html @@ -576,6 +576,13 @@ Addr: -
Float: -

+

Deprecated. Use `a:contains/string?` instead. Return `TRUE` if the string value is in the array or `FALSE` otherwise.

+
Class: class:word
Namespace: a
Interface Layer: all

+

a:contains/string?

+

Data: sa-f
+Addr: -
+Float: -

+

Return `TRUE` if the string value is in the array or `FALSE` otherwise.

Class: class:word
Namespace: a
Interface Layer: all

a:contains?

@@ -2912,13 +2919,27 @@ Addr: -
Float: -

-

Return `TRUE` if the character is present in the string or `FALSE` otherwise.

+

Deprecated. Use `s:contains/char?` instead. Return `TRUE` if the character is present in the string or `FALSE` otherwise.

Class: class:word
Namespace: s
Interface Layer: all

s:contains-string?

Data: ss-f
Addr: -
Float: -

+

Deprecated. Use `s:contains/string?` instead. Return `TRUE` if the second string is present in the first string or `FALSE` otherwise.

+
Class: class:word
Namespace: s
Interface Layer: all

+

s:contains/char?

+

Data: sc-f
+Addr: -
+Float: -

+
+

Return `TRUE` if the character is present in the string or `FALSE` otherwise.

+
Class: class:word
Namespace: s
Interface Layer: all

+

s:contains/string?

+

Data: ss-f
+Addr: -
+Float: -

+

Return `TRUE` if the second string is present in the first string or `FALSE` otherwise.

Class: class:word
Namespace: s
Interface Layer: all

s:copy

diff --git a/doc/Glossary.txt b/doc/Glossary.txt index 452bb30..ec9cf23 100644 --- a/doc/Glossary.txt +++ b/doc/Glossary.txt @@ -895,6 +895,17 @@ a:contains-string? Addr: - Float: - +Deprecated. Use `a:contains/string?` instead. Return `TRUE` if the string value is in the array or `FALSE` otherwise. + +Class: class:word | Namespace: a | Interface Layer: all +------------------------------------------------------------------------ + +a:contains/string? + + Data: sa-f + Addr: - + Float: - + Return `TRUE` if the string value is in the array or `FALSE` otherwise. Class: class:word | Namespace: a | Interface Layer: all @@ -4498,7 +4509,7 @@ s:contains-char? Addr: - Float: - -Return `TRUE` if the character is present in the string or `FALSE` otherwise. +Deprecated. Use `s:contains/char?` instead. Return `TRUE` if the character is present in the string or `FALSE` otherwise. Class: class:word | Namespace: s | Interface Layer: all ------------------------------------------------------------------------ @@ -4509,6 +4520,28 @@ s:contains-string? Addr: - Float: - +Deprecated. Use `s:contains/string?` instead. Return `TRUE` if the second string is present in the first string or `FALSE` otherwise. + +Class: class:word | Namespace: s | Interface Layer: all +------------------------------------------------------------------------ + +s:contains/char? + + Data: sc-f + Addr: - + Float: - + +Return `TRUE` if the character is present in the string or `FALSE` otherwise. + +Class: class:word | Namespace: s | Interface Layer: all +------------------------------------------------------------------------ + +s:contains/string? + + Data: ss-f + Addr: - + Float: - + Return `TRUE` if the second string is present in the first string or `FALSE` otherwise. Class: class:word | Namespace: s | Interface Layer: all diff --git a/doc/words.tsv b/doc/words.tsv index 5c484a0..516cbae 100644 --- a/doc/words.tsv +++ b/doc/words.tsv @@ -76,7 +76,8 @@ a:-eq? aa-f - - Compare all values in the array. Return `FALSE` if all values ar a:append aa-a - - Return a new array consisting of the values in a1 followed by the values in a2. class:word {n/a} {n/a} a all a:begins-with? aa-f - - Return `TRUE` if a1 begins with a2 or `FALSE` otherwise. class:word {n/a} {n/a} a all a:chop a-a - - Return a new array containing all but the last value in the source array. class:word {n/a} {n/a} a all -a:contains-string? sa-f - - Return `TRUE` if the string value is in the array or `FALSE` otherwise. class:word {n/a} {n/a} a all +a:contains-string? sa-f - - Deprecated. Use `a:contains/string?` instead. Return `TRUE` if the string value is in the array or `FALSE` otherwise. class:word {n/a} {n/a} a all +a:contains/string? sa-f - - Return `TRUE` if the string value is in the array or `FALSE` otherwise. class:word {n/a} {n/a} a all a:contains? na-f - - Return `TRUE` if the value is in the array or `FALSE` otherwise. class:word {n/a} {n/a} a all a:copy aa- - - Copy an array (a1) to a destination (a2). class:word {n/a} {n/a} a all a:counted-results q-a - - Run a quote and construct a new array from the returned values. The quote should return the values and the number of values to put into the array. class:word {n/a} {n/a} a all @@ -384,8 +385,10 @@ s:begins-with? ss-f - - Return `TRUE` if s1 begins with s2 or `FALSE` otherwise. s:case sSq- || sSq-s - - If the `s` matches `S`, discard `s` and run the quote before exiting the caller. If they do not match, discard the quote and leave `s` on the stack. class:word {n/a} {n/a} s all s:chop s-s - - Remove the last character from a string. Returns a new string. class:word {n/a} {n/a} s all s:const ss- - - Create a constant named s2, returning a pointer to s1. This will use `s:keep` to preserve the original string. class:word {n/a} {n/a} s all -s:contains-char? sc-f - - Return `TRUE` if the character is present in the string or `FALSE` otherwise. class:word {n/a} {n/a} s all -s:contains-string? ss-f - - Return `TRUE` if the second string is present in the first string or `FALSE` otherwise. class:word {n/a} {n/a} s all +s:contains-char? sc-f - - Deprecated. Use `s:contains/char?` instead. Return `TRUE` if the character is present in the string or `FALSE` otherwise. class:word {n/a} {n/a} s all +s:contains-string? ss-f - - Deprecated. Use `s:contains/string?` instead. Return `TRUE` if the second string is present in the first string or `FALSE` otherwise. class:word {n/a} {n/a} s all +s:contains/char? sc-f - - Return `TRUE` if the character is present in the string or `FALSE` otherwise. class:word {n/a} {n/a} s all +s:contains/string? ss-f - - Return `TRUE` if the second string is present in the first string or `FALSE` otherwise. class:word {n/a} {n/a} s all s:copy sa- - - Copy a string (s) to a destination (a). This will include the terminator character when copying. class:word {n/a} {n/a} s all s:empty -s - - Return an empty string. class:word {n/a} {n/a} s all s:ends-with? ss-f - - Return `TRUE` if s1 ends with s2 or `FALSE` otherwise. class:word {n/a} {n/a} s all diff --git a/example/7080.retro b/example/7080.retro index 95299b2..16d502f 100755 --- a/example/7080.retro +++ b/example/7080.retro @@ -148,7 +148,7 @@ that provide a hint to the user about the content being linked. @Line [ ' s:put s:put ' s:put ] a:for-each nl ; :line - dup ASCII:HT s:contains-char? + dup ASCII:HT s:contains/char? [ fields a:length #3 gteq? [ [ menu-entry ] [ plain-text ] choose ] if; [ s:putm ] tt ; @@ -164,7 +164,7 @@ that provide a hint to the user about the content being linked. [ s:trim line ] a:for-each ; :process - &Buffer ASCII:HT s:contains-char? [ process:line ] if; + &Buffer ASCII:HT s:contains/char? [ process:line ] if; ' s:put &Buffer s:put ' s:put ; :eol ASCII:CR c:put ASCII:LF c:put ; diff --git a/example/Casket-HTTP.retro b/example/Casket-HTTP.retro index 078a1bd..a4318bd 100755 --- a/example/Casket-HTTP.retro +++ b/example/Casket-HTTP.retro @@ -82,7 +82,7 @@ the requested file from any query string that may be present. [ '/ &Requested s:append s:keep &Requested s:copy ] if ; :check-for-params (-) - &Requested $? s:contains-char? + &Requested $? s:contains/char? [ &Requested $? s:split/char drop dup n:inc !GET-Query #0 swap store ] if ; :filename (-s) diff --git a/example/advent-of-code-2020-day-4.retro b/example/advent-of-code-2020-day-4.retro index 739f50f..97d88ff 100644 --- a/example/advent-of-code-2020-day-4.retro +++ b/example/advent-of-code-2020-day-4.retro @@ -106,15 +106,15 @@ each one that proves valid. ~~~ :valid? - [ [ 'byr: s:contains-string? ] - [ 'iyr: s:contains-string? ] - [ 'eyr: s:contains-string? ] tri and and ] + [ [ 'byr: s:contains/string? ] + [ 'iyr: s:contains/string? ] + [ 'eyr: s:contains/string? ] tri and and ] - [ [ 'hgt: s:contains-string? ] - [ 'hcl: s:contains-string? ] - [ 'ecl: s:contains-string? ] tri and and ] + [ [ 'hgt: s:contains/string? ] + [ 'hcl: s:contains/string? ] + [ 'ecl: s:contains/string? ] tri and and ] - [ 'pid: s:contains-string? ] tri and and ; + [ 'pid: s:contains/string? ] tri and and ; #0 &Passports [ valid? [ n:inc ] if ] a:for-each ~~~ @@ -209,9 +209,9 @@ Then I implement the checks for each field. [ height-metric? ] [ height-imperial? ] choose record-result ; :process-hcl [ fetch $# eq? ] [ s:length #7 eq? ] - [ [ 'abcdef0123456789 swap s:contains-char? ] s:filter s:length #6 eq? ] tri + [ [ 'abcdef0123456789 swap s:contains/char? ] s:filter s:length #6 eq? ] tri and and record-result ; -:process-ecl EYE-COLORS a:contains-string? record-result ; +:process-ecl EYE-COLORS a:contains/string? record-result ; :process-pid [ s:length #9 eq? ] [ [ c:digit? ] s:filter s:length #9 eq? ] bi and record-result ; ~~~ diff --git a/example/atua-gophermap.retro b/example/atua-gophermap.retro index 5032275..c60cb35 100755 --- a/example/atua-gophermap.retro +++ b/example/atua-gophermap.retro @@ -144,7 +144,7 @@ Then I look to see if it has a file extension. ~~~ :has-extension? (s-sf) - dup $. s:contains-char? ; + dup $. s:contains/char? ; ~~~ If there is an extension, it can be mapped to a type code. diff --git a/example/display-names.retro b/example/display-names.retro index cdbb6c4..9ae5568 100644 --- a/example/display-names.retro +++ b/example/display-names.retro @@ -62,7 +62,7 @@ any used space is recovered. {{ :identify-classes (-a) here #0 , - [ dup d:name 'class: s:contains-string? + [ dup d:name 'class: s:contains/string? &, &drop choose ] d:for-each here over - n:dec over store ; ---reveal--- diff --git a/example/enum.retro b/example/enum.retro index abf49d4..f5b164b 100644 --- a/example/enum.retro +++ b/example/enum.retro @@ -32,7 +32,7 @@ increments the counter. ~~~ :a:enum (a-) #0 swap - [ dup $= s:contains-char? + [ dup $= s:contains/char? [ nip $= s:split/char [ n:inc s:to-number ] dip ] if over &const dip n:inc ] a:for-each drop ; diff --git a/example/file.retro b/example/file.retro index 7041feb..2864604 100644 --- a/example/file.retro +++ b/example/file.retro @@ -38,7 +38,7 @@ Works imperfectly, but useful. [ drop SOURCE/RETRO ] [ d:name ] choose !FileName ; :count-lines (-) #1 !Line (open @FileName file:open-for-reading !FileID !Size ) - [ @FileID file:read-line word-name s:contains-string? + [ @FileID file:read-line word-name s:contains/string? dup [ &Line v:inc ] -if not (-eof? @FileID file:tell @Size lt? ) and ] while (close @FileID file:close ) ; :pre (a-f) word file ; @@ -61,4 +61,3 @@ will not be found correctly.. Also, words defined in Rx such as `push`, `pop`, `drop`, `swap`, and `dup` are not found. - diff --git a/example/irc-bot.retro b/example/irc-bot.retro index b767ae5..ba0594f 100644 --- a/example/irc-bot.retro +++ b/example/irc-bot.retro @@ -143,7 +143,7 @@ I pass it to `s:evaluate`, capturing and relaying the output. #128 allot :message? - here 'PRIVMSG s:contains-string? ; + here 'PRIVMSG s:contains/string? ; :channel here 'PRIVMSG s:split-on-string drop #8 + $: s:split nip s:chop &Channel s:copy ; diff --git a/example/muri-with-hex.retro b/example/muri-with-hex.retro index ee994d5..bfbb68f 100644 --- a/example/muri-with-hex.retro +++ b/example/muri-with-hex.retro @@ -117,7 +117,7 @@ hex conversion above. ~~~ :decode (s-n) - dup &Instructions a:contains-string? + dup &Instructions a:contains/string? [ &Instructions swap a:index-of-string ] [ s:to-hex-number ] choose ; ~~~ diff --git a/example/namespaces.retro b/example/namespaces.retro index 7017b26..e2a36bb 100644 --- a/example/namespaces.retro +++ b/example/namespaces.retro @@ -11,9 +11,9 @@ Three words will be exposed. 'Namespaces d:create #513 allot {{ - :has-namespace? dup $: s:contains-char? ; + :has-namespace? dup $: s:contains/char? ; :get-namespace $: s:split nip ; - :known? dup &Namespaces a:contains-string? ; + :known? dup &Namespaces a:contains/string? ; :add s:keep buffer:add &Namespaces v:inc ; :process get-namespace known? &drop &add choose ; ---reveal--- diff --git a/example/retro-edit.retro b/example/retro-edit.retro index 59846ed..67c27b3 100755 --- a/example/retro-edit.retro +++ b/example/retro-edit.retro @@ -198,7 +198,7 @@ display a range of lines, use `p`, followed by a `first,last` line number pair. ~~~ -:pair? @Input $, s:contains-char? ; +:pair? @Input $, s:contains/char? ; :get-limits @Input $, s:tokenize [ s:to-number ed:constrain ] a:for-each ; :display-range over - n:inc [ dup ed:display-line n:inc ] times drop ; @@ -211,7 +211,7 @@ The final display related command is `/`, which displays lines that contain the text following the `/`. ~~~ -:match? I ed:to-line @Input s:contains-string? ; +:match? I ed:to-line @Input s:contains/string? ; :cmd:/ @Lines [ match? [ I ed:display-line ] if ] indexed-times ; ~~~ diff --git a/example/retro-stats.retro b/example/retro-stats.retro index cb74896..3c187c7 100644 --- a/example/retro-stats.retro +++ b/example/retro-stats.retro @@ -85,7 +85,7 @@ nl 'Classes: s:put nl nl :identify-classes (-a) here #0 , - [ d:name dup 'class: s:contains-string? + [ d:name dup 'class: s:contains/string? &, &drop choose ] d:for-each here over - n:dec over store ; @@ -109,7 +109,7 @@ nl 'Sigils: s:put nl nl :identify-sigils (-a) here #0 , - [ d:name dup 'sigil: s:contains-string? + [ d:name dup 'sigil: s:contains/string? &, &drop choose ] d:for-each here over - n:dec over store ; diff --git a/image/retro.forth b/image/retro.forth index 57f87ba..f044a4f 100644 --- a/image/retro.forth +++ b/image/retro.forth @@ -907,11 +907,11 @@ In higher level code: [ drop #-1 ] if ; ~~~ -`s:contains-char?` returns a flag indicating whether or not a +`s:contains/char?` returns a flag indicating whether or not a given character is in a string. ~~~ -:s:contains-char? (sc-f) s:index-of #-1 -eq? ; +:s:contains/char? (sc-f) s:index-of #-1 -eq? ; ~~~ Hash (using DJB2) @@ -925,7 +925,7 @@ on an implementation at http://www.cse.yorku.ca/~oz/hash.html :s:hash (s-n) #5381 swap [ \swlimuad `33 ] s:for-each ; ~~~ -`s:contains-string?` returns a flag indicating whether or not +`s:contains/string?` returns a flag indicating whether or not a given substring is in a string. ~~~ @@ -949,7 +949,7 @@ a given substring is in a string. :next (-) &I v:inc ; ---reveal--- - :s:contains-string? (ss-f) + :s:contains/string? (ss-f) !Tar !Src s:empty !Pad #0 !I #0 !F @Src s:length [ extract terminate compare next ] times @@ -1099,9 +1099,9 @@ First are a bunch of words to help identify character values. :c:letter? (c-f) &c:lowercase? &c:uppercase? bi or ; :c:digit? (c-f) $0 $9 n:between? ; :c:visible? (c-f) #32 #126 n:between? ; -:c:vowel? (c-f) 'aeiouAEIOU swap s:contains-char? ; +:c:vowel? (c-f) 'aeiouAEIOU swap s:contains/char? ; :c:consonant? (c-f) dup c:letter? [ c:vowel? not ] [ drop FALSE ] choose ; -:c:whitespace? (c-f) s:WHITESPACE swap s:contains-char? ; +:c:whitespace? (c-f) s:WHITESPACE swap s:contains/char? ; ~~~ And the inverse forms. (These are included for readability and @@ -1476,7 +1476,7 @@ a `TRUE` flag for. here over - n:dec over store ; ~~~ -Next are `a:contains?` and `a:contains-string?` which +Next are `a:contains?` and `a:contains/string?` which compare a given value to each item in the array and returns a flag. @@ -1484,7 +1484,7 @@ a flag. :a:contains? (na-f) #0 swap [ swap push over eq? pop or ] a:for-each nip ; -:a:contains-string? (na-f) +:a:contains/string? (na-f) #0 swap [ swap push over s:eq? pop or ] a:for-each nip ; ~~~ diff --git a/ngaImage b/ngaImage index e129f31..6aa6465 100644 Binary files a/ngaImage and b/ngaImage differ diff --git a/package/dict-words-listing.forth b/package/dict-words-listing.forth index 8fd4632..2912a66 100644 --- a/package/dict-words-listing.forth +++ b/package/dict-words-listing.forth @@ -19,7 +19,7 @@ words that likely display something: `':put d:words-with`. :d:words-with (s-) here s:copy [ d:name dup here - (put-match s:contains-string? [ s:put sp ] [ drop ] choose ) + (put-match s:contains/string? [ s:put sp ] [ drop ] choose ) ] d:for-each ; ~~~ @@ -28,11 +28,11 @@ it does not care where in the name the substring is found. To deal with this, `d:words-beginning-with` is provided. ~~~ -{{ +{{ :display-if-left (s-) - dup here s:begins-with? [ s:put sp ] [ drop ] choose ; ----reveal--- + dup here s:begins-with? [ s:put sp ] [ drop ] choose ; +---reveal--- :d:words-beginning-with (s-) - here s:copy [ d:name display-if-left ] d:for-each ; -}} + here s:copy [ d:name display-if-left ] d:for-each ; +}} ~~~ diff --git a/package/extensions/deprecated.retro b/package/extensions/deprecated.retro index 31e2900..3b4b2ad 100644 --- a/package/extensions/deprecated.retro +++ b/package/extensions/deprecated.retro @@ -1,5 +1,8 @@ ~~~ :s:split (sc-ss) s:split/char ; :s:split-on-string (ss-ss) s:split/string ; +:s:contains-char? s:contains/char? ; +:s:contains-string? s:contains/string? ; +:a:contains-string? s:contains/string? ; ~~~ diff --git a/tools/glossary.retro b/tools/glossary.retro index 74df68c..9830b6f 100755 --- a/tools/glossary.retro +++ b/tools/glossary.retro @@ -283,7 +283,7 @@ before doing the checks. :record-name !SourceLine field:name s:keep over &GlossaryNames + store ; :populate-names #1 'doc/words.tsv [ record-name n:inc ] file:for-each-line n:dec &GlossaryNames store ; - :in-set? dup &GlossaryNames a:contains-string? ; + :in-set? dup &GlossaryNames a:contains/string? ; ---reveal--- :display-missing restrict-scope populate-names diff --git a/vm/nga-c/image.c b/vm/nga-c/image.c index 1291913..56804e9 100644 --- a/vm/nga-c/image.c +++ b/vm/nga-c/image.c @@ -10,8 +10,8 @@ #define CELL_MAX LLONG_MAX - 1 #endif #endif -CELL ngaImageCells = 14999; -CELL ngaImage[] = { 1793,14780,14974,14998,202107,379,351,1030,1535,0,10,1,10,2,10,3,10,4,10, +CELL ngaImageCells = 15072; +CELL ngaImage[] = { 1793,14780,15046,15071,202107,379,351,1030,1535,0,10,1,10,2,10,3,10,4,10, 5,10,6,10,7,10,8,10,11,10,12,10,13,10,14,10,15,10,16,10, 17,10,18,10,19,10,20,10,21,10,22,10,23,10,24,10,25,68223234,1,2575, 85000450,1,656912,140,157,268505089,63,62,285281281,0,63,2063,10,101384453,0,9,10,2049,56,25, @@ -63,7 +63,7 @@ CELL ngaImage[] = { 1793,14780,14974,14998,202107,379,351,1030,1535,0,10,1,10,2, 0,961,4,133,86,101,114,115,105,111,110,0,980,426,145,105,0,991,107,145, 100,0,996,420,145,114,0,1001,205,133,66,97,115,101,0,1006,351,145,101,114, 114,58,110,111,116,102,111,117,110,100,0,105,109,97,103,101,58,115,97,118, - 101,0,103,101,0,0,105,110,103,0,116,101,100,46,114,101,116,114,111,0, + 101,0,103,101,0,105,110,103,63,0,0,101,100,46,114,101,116,114,111,0, 110,100,0,126,0,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86, 87,88,89,90,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, @@ -213,7 +213,7 @@ CELL ngaImage[] = { 1793,14780,14974,14998,202107,379,351,1030,1535,0,10,1,10,2, 3992,145,115,58,105,110,100,101,120,45,111,102,0,4,1793,4006,68223234,1,6415,33883396, 101450758,6404,3,1,3995,7,10,1,3995,1793,4015,18,2049,2993,772,10,1,4010,1793,4024, 2049,81,67502597,11,10,1,4019,2049,2214,1793,4034,3,1,-1,10,1,4030,9,10,3978, - 4058,145,115,58,99,111,110,116,97,105,110,115,45,99,104,97,114,63,0,2049, + 4058,145,115,58,99,111,110,116,97,105,110,115,47,99,104,97,114,63,0,2049, 3992,1,-1,12,10,4038,4074,145,115,58,104,97,115,104,0,1,5381,4,1793,4082, 286458116,33,10,1,4079,2049,3958,10,4064,4094,133,83,114,99,0,0,4087,4102,133,84, 97,114,0,0,4095,4110,133,80,97,100,0,0,4103,4116,133,73,0,0,4111,4122, @@ -223,7 +223,7 @@ CELL ngaImage[] = { 1793,14780,14974,14998,202107,379,351,1030,1535,0,10,1,10,2, 4154,4190,145,99,111,109,112,97,114,101,0,3841,4110,3841,4102,2049,95,3841,4122,22, 4097,4122,3841,4122,1793,4210,3841,4116,4097,4129,10,1,4205,2049,72,10,4179,4223,145,110, 101,120,116,0,1,4116,2049,3077,10,4064,4250,145,115,58,99,111,110,116,97,105, - 110,115,45,115,116,114,105,110,103,63,0,4097,4102,4097,4094,2049,3716,4097,4110,1, + 110,115,47,115,116,114,105,110,103,63,0,4097,4102,4097,4094,2049,3716,4097,4110,1, 0,4097,4116,1,0,4097,4122,3841,4094,2049,81,1793,4281,2049,4165,2049,4143,2049,4190,2049, 4223,10,1,4272,2049,2330,3841,4122,10,4228,4295,133,83,116,114,0,0,4288,4307,145, 101,120,116,114,97,99,116,0,2049,2145,3841,4295,4,2049,3215,3841,-1,67502597,17,1, @@ -416,7 +416,7 @@ CELL ngaImage[] = { 1793,14780,14974,14998,202107,379,351,1030,1535,0,10,1,10,2, 64,10,1,8028,2049,7588,2049,1929,1793,8056,67502597,15,2049,107,2049,7820,10,1,8049,2049, 2155,2049,1929,67502597,18,2049,2993,67502597,16,10,8014,8084,145,97,58,99,111,110,116,97, 105,110,115,63,0,1,0,4,1793,8096,4,5,67502597,11,6,22,10,1,8089,2049, - 7820,772,10,8069,8124,145,97,58,99,111,110,116,97,105,110,115,45,115,116,114, + 7820,772,10,8069,8124,145,97,58,99,111,110,116,97,105,110,115,47,115,116,114, 105,110,103,63,0,1,0,4,1793,8137,4,5,67502597,2049,95,6,22,10,1,8129, 2049,7820,772,10,8102,8152,145,97,58,109,97,112,0,1793,8158,8,2049,107,10,1, 8154,2049,7588,2049,1929,1793,8173,67502597,15,2049,107,2049,7820,10,1,8166,2049,2155,10,8143, @@ -760,4 +760,8 @@ CELL ngaImage[] = { 1793,14780,14974,14998,202107,379,351,1030,1535,0,10,1,10,2, 14944,145,100,58,119,111,114,100,115,45,98,101,103,105,110,110,105,110,103,45, 119,105,116,104,0,2049,1929,2049,4736,1793,14955,2049,163,2049,14895,10,1,14950,2049,7640, 10,14918,14971,145,115,58,115,112,108,105,116,0,2049,6201,10,14960,14995,145,115,58, - 115,112,108,105,116,45,111,110,45,115,116,114,105,110,103,0,2049,6233,10,0 }; + 115,112,108,105,116,45,111,110,45,115,116,114,105,110,103,0,2049,6233,10,14974, + 15018,145,115,58,99,111,110,116,97,105,110,115,45,99,104,97,114,63,0,2049, + 4058,10,14998,15043,145,115,58,99,111,110,116,97,105,110,115,45,115,116,114,105, + 110,103,63,0,2049,4250,10,15021,15068,145,97,58,99,111,110,116,97,105,110,115, + 45,115,116,114,105,110,103,63,0,2049,4250,10,0 };