Please enable JavaScript to view this site.

A-Shell Reference

Navigation: System Commands > COMPIL

Compiler Edit History

Scroll Prev Top Next More

The following list, extracted from the A-Shell Development notes, shows all compiler edits, including fixes and minor changes. Missing descriptions indicate that the edit in question was a purely internal matter that did not affect the operation of A-Shell.

Compiler
Edit #

A-Shell
Version

Release
Date

Description

1048

1765.9

05 Dec 2024

Fix: structure-type function parameters with default values were triggering spurious compiler syntax errors.

1047

1765.6

24 Nov 2024

Fixes:

•   Specifying a default value for a parameter in a function declaration was effectively overriding the outputonly clause.

•   The :outputonly attribute was making it impossible to specify that parameter by name in a DYNFUNC() call.

1046

1757.5

29 Apr 2024

Add some performance statistics to the end of the LSX file.

1045

1757.5

29 Apr 2024

++IFDEF <structname> was not working properly during the /px pre-scan, resulting in spurious "function not defined" errors if the target function was dependent on such a conditional.

1044

1756.1

01 Mar 2024

With the /X:2 switch, an OPEN statement whose RECNO variable was the last variable MAPped was generating a spurious illegal variable size error.

1043

1756.0

20 Feb 2024

Add new ASB control statement EXITPROGRAM.

1042

1752.5

13 Dec 2023

1. Extend the 1041 edit to treat all case variations of a variable named DATN (datn, DatN, etc.) in a MAP statement, whether scalar or array, as entirely disabling recognition of the double-arctangent function—i.e. reverting entirely to the behavior before that function was introduced.

2. Compiler now complains about INPUT statements targeting an array or a gridmap that are missing the CSV token.

1041

1752.2

04 Dec 2023

DATN is no longer treated as a keyword (double arctangent function) if it appears in a MAP statement first.

1040

1751.4

04 Nov 2023

Internal cleanup of potential 64 bit overflow issues.

1039

 

 

 

1038

1750.3

08 Oct 2023

Eliminate bogus runtime error 74 when passing a collection via DYNFUNC.

1037

1742.0

25 Sept 2023

PRIVATE blocks in a main program module were not getting initialized by the first function call. This would have been a problem if the block contained DIMX statements or actual code that needed to be executed.

1036

1742.0

25 Sept 2023

WRITECD ARY() statement now supports numeric array types as well as gridmaps.

1035

 

 

 

1034

1739.4

15 Aug 2023

Add new convenience operator to assign elements to an array in a single operation from a CSV-formatted string:

1033

1735.2

02 Aug 2023

Transclude fix: Eliminate spurious errors when the TCF spec in a ++include statement contained a device prefix.

1032

1735.2

02 Aug 2023

Transclude fix: Private variables in transcluded modules weren't getting initialized.

1031

1735.2

28 July 2023

Transclude fix: Eliminate spurious errors when the TCF spec in a ++include statement contained a device prefix.

1030

1735.1

27 July 2023

Transclude fixes:

•   Failure to specify a TCF section in the ++include line was causing the operation to ignore the TCF file contents.

•   PRIVATE module variables now work as expected in transcluded modules. Previously, the compiler was complaining of duplicate variables.

1029

1735.0

23 July 2023

Transclude fix: ++include with [p,pn] was getting confused with the new transclude syntax.

1028

1735.0

23 July 2023

Correct problem with spurious errors caused by appearance of keywords in DEFXCALL parameter lists. Problem was introduced in edit 1020.

1027

1734.4

07 July 2023

Transclude statement was treating spaces after the second comma (separating the TCF spec from the section name) as significant, almost certainly causing it to abort with a section not found error.

1026

1733.0.3

19 June 2023

Provide support for storing a label reference in a numeric variable and then using it as the target of a GOTO, CALL or GOSUB statement.

1025

1732.0.4

12 June 2023

Add support for "transclude" variation of ++include directives.

1024

1731.2

06 June 2023

Correct another variation of the bug partially fixed in edit 1023.

1023

1731.1

06 June 2023

Correct an issue introduced in compiler edit 1022 resulting in bogus compiler errors for certain combinations of ordered map parameter passing.

1022

1731.0.1

29 May 2023

Compiler now complains about mismatched collection arrays passed by reference to functions.

1021

1730.5.3

23 May 2023

++IFDEF directive now recognizes DEFXCALL.

1020

1730.5.2

23 May 2023

DEFXCALL now allows subroutine names that are also keywords—e.g. XCALL AMOS. Standard include file ashinc:xcall.def updated accordingly.

1019

1728.2

25 Mar 2023

RUN header was getting corrupted if program had more than 8K of DATA statement values and a minimum run version requirement. VERSYS would report the bad header but the runtime system would most likely crash if program was run.

1018

1728.1.2

25 Mar 2023

Remove a spurious syntax error when the READ'ONLY option was included on a file opened in RANDOM mode.

1017

1728.1.1

25 Mar 2023

Compiler edit 1017: ORDMAPM assignments were not being compiled correctly, resulting in null values being assigned. Introduced in compiler edit 1016.

1016

 

 

 

1015

1727.0.2

11 Mar 2023

An ordered map copy of the form $map1() = $map2() may have triggered a spurious syntax error in the subsequent statement.

1014

1725.0.1

14 Feb 2023

Add support for trigonometric DATN function.

1013

1724.0.4

06 Feb 2023

DIMX arrays of type B, F and I may now be passed by reference to functions.

1012

1724.0.3

06 Feb 2023

DIMX arrays of type S may now be passed by reference to functions. Previously, only type X was allowed.

1011

1724.0.2

06 Feb 2023

Resolve a conflict between the GLOBAL_BEGIN pragma and dynamic structure compilation that was causing spurious compiler errors.

1010

1724.0.1

06 Feb 2023

Minor internal adjustments to improve code portability and robustness.

1009

1721.7.1

09 Nov 2022

DATA statements longer than 512 bytes were overflowing an internal statement buffer without triggering a proper compiler error, in some cases causing the compiler to crash. The limit has been increased to 1024. However, note that multi-term DATA statements can always be broken up into multiple DATA statements; the limit will therefore only be an obstacle in cases where the length of a single DATA term exceeds it.

1008

1721.3.1

05 Oct 2022

The embedded DEFSTRUCT index wasn't being terminated properly, leading to DEFSTRUCT/DYNSTRUCT binding errors under certain sequences.

1007

1721.1

28 Sept 2022

DEFSTRUCT members with initial values or overlays were not being compiled correctly, typically either leading to bogus compiler error messages or invalid syntax or out of memory errors when using DIMX to create an array of structure elements.

1006

1721.1.4

25 Sept 2022

Close a loophole in which certain array variable references nested within with function parameter lists were triggering bogus unmapped variable compiler errors.

1005

1721.1.3

25 Sept 2022

Auto-binding of a DEFSTRUCT to a DYNSTRUCT when passing parameters to a function was not working for function parameters defined with default values.

1004

1721.1.2

25 Sept 2022

DEFSTRUCTs embedded in the RUN file were missing DEFTYPE information—i.e. any DEFTYPEs in the DEFSTRUCT were converted to the native types.

1003

1720.7.1

14 Sept 2022

/F1 switch wasn't eliminating all minimum run versions from the header.

1002

1720.4

07 Sept 2022

A label named SET'RECNO or XOPEN was incorrectly setting the minimum runtime version in the RUN header to 1684, as if it had seen the statements by those names.

1001

1720.0.8

31 Aug 2022

Language enhancement, compiler edit 1001: The CALL statement can now be used to invoke a dynamic function. For example:

CALL DYNFUNC(func$,args...)

CALL DYNFUNC$(func$,args...)

This is analogous to using the CALL statement with static function, and is more natural than a dummy assignment when you don't care about the return value of the function. Requires A-Shell 6.5.1720+.

1000

1720.0.5

31 Aug 2022

Language enhancement: named parameters can now be used with DYNFUNC, e.g.

 

DYNFUNC(fname$, argx=valuex, argy=value1)

 

Note that this affects both the compiler and runtime, so the use of named parameters in a DYNFUNC expression will now set the minimum runtime level to 6.5.1720.

1720.0.7

31 Aug 2022

/CI support now extended to dynamic functions, both the function names and argument names.

999

1720.0.6

31 Aug 2022

Language enhancement: default parameter values are now supported in dynamic functions. Previously the compiler didn't complain, since functions declared dynamic can still be called statically.
 

Note that in the case of dynamic functions, default values are limited to constant expressions, whereas for static functions, they could involve variables.
 

Use of default values in a dynamic function definition now sets the minimum runtime level to 1720, so programs that ran under earlier runtimes (whether or not the default values were respected) will now require the 6.5.1720+ runtime.

998

1717.14.14

03 Aug 2022

• The /CI (case insensitive) option was affecting DEFINEd literal strings. This bug was introduced in edit 994).

• Symbol definitions passed in via the /C: switch were being lost if the program was too big for the specified options, leading to an automatic compilation restart with the /A or /AV switches activated.

997

1717.13.2

02 Aug 2022

Internal compiler code refinements.

996

1717.12.1

27 July 2022

Fix crash related to embedded defstructs.

995

1717.4.2

9 June 2022

the existence of a ++ directived within the text following a ++MESSAGE or ++ERROR directive was in some cases confusing the compiler as to conditional compilation state.

994

1717.4.1

9 June 2022

Refinements to DEFALIAS:

•  ++IFLBL / ++IFNLBL now recognize DEFALIAS'd function and procedure labels, acting based on the existence of the target function / procedure (and not the existence of the DEFALIAS definition).

•  ++IFDEF / ++IFNDEF now treat DEFALIAS definitions as they would symbols defined via DEFINE statements.

•  UNDEF now works on DEFALIAS definitions.

993

1716.6.2

26 May 2022

fix several issues related to .SUBLIST and .SPLICE: (1) passing a .SUBLIST to a function expecting a list was causing a spurious array vs. scalar mismatch compilation error; (2) in some statements a .SUBLIST was being treated as scalar variable, possibly leading to a spurious compilation error or real runtime error; (3) a FOREACH statement iterating through a .SUBLIST may have thrown a spurious compilation error; (4) the 3-argument version of .SPLICE was being compiled incorrectly, leading to possible stack corruption at runtime.

992

1716.6.1

26 May 2022

attempting a private instantiation of a DEFSTRUCT containing overlaid variables was resulting in a spurious compiler error.

991

 

 

 

990

1716.3.1

19 May 2022

close a loophole in which function call parameter lists containing literals might trigger a spurious syntax error or fail to compile correctly. Also syntax error messages now display a suffix "-->> xxx ..." where xxx indicates the part of the line where the syntax error was detected. This is mainly helpful in very long source lines where it is sometimes difficult to find the missing or misplaced character.

989

1715.12.2

13 May 2022

close a loophole introduced in edit 984 resulting in the corruption of some function calls and XCALLs, primarily in the CentOS environment.

988

1715.12.1

13 May 2022

minor refinements to the LSX file structure to ensure that the LSX compilation is fully independent of the environment in which it was created.

987

1715.11.2

13 May 2022

fix problem with ++INCLUDE'IF'EXISTS when compiling an LSX file in a different environment than where the LSX file was originally created. If the existence at the time the LSX was created didn't agree with the existence when compiling the LSX, the ++include nesting levels would get out of sync with the original, possibly leading to bogus compilation errors.

986

1715.10

06 May 2022

the first unmapped variable, if numeric, was failing to finalize the definition of last mapped variable, causing it to behave in certain expressions as if it had the default size for its type. Problem was introduced in one of the early 6.5 versions.

985

1715.9.1

03 May 2022

DEFTYPEs associated with structure members were not being saved or retrieved by the MX_DYNSTRUCT operations. The native type,size info was still correct, but applications relying on on the DEFTYPEs were out of luck. Bug was introduced in 6.5.1711.

984

1715.8.1

01 May 2022

tighten the syntax checking on named parameter lists (both XCALL and function/procedure) to require that scalar parameters are passed scalar values and array (byref) arguments are passed array (byref) values.

983

1715.7.1

23 Apr 2022

further refinement to edit 982 to eliminate spurious complaint about XCALL array parameters with spaces within the parentheses, e.g. XCALL MYSBX, ARY( 1 ), ...

982

1715.6.1

22 Apr 2022

replacement for edit 981 (which was recalled).

981

1715.5.1

21 Apr 2022

extend the fix in edit 978 to apply to XCALL named parameters (defined with DEFXCALL).

980

1714.3.1

21 Apr 2022

fix for spurious error "cannot input from output-only parameter) on XGETARG when the specified argument number was one beyond the number of parameters formally declared. Apply range checking on the XGETARG argument number to make sure > 0 and < 1024 (max).

979

1714.2.1

12 Apr 2022

RND2 / SRND2 were failing to set the minimum runtime version to 1517.

978

1714.1.1

08 Apr 2022

fix problem introduced in edit 975 causing spurious undefined parameter errors with function parameter definitions of the form $ary()=.NULL as ordmap(...).

977

1713.0.1

08 Apr 2022

new system function TRIM(strexp), or TRIM$(strexp). This removes the leading and trailing blanks from the string expression argument, equivalent to the combination of STRIP$(strexp) and LSTRIP$(strexp).

976

1712.4.3

21 Mar 2022

MX_DYNSTRUCT DYNOP_DEF calls referencing file-based DEFSTRUCTs were incorrectly handling array members of the structure if the file contained a ++PRAGMA PRIVATE section prior to the DEFSTRUCT.

975

1712.4.2

20 Mar 2022

named parameter references to arrays (byref) were incorrectly accepting scalar parameter name syntax.

974

1712.4.1

20 Mar 2022

various minor improvements to the clarity of certain error messages.

973

1712.3.1

20 Mar 2022

the ++PRAGMA GLOBAL_xxx was causing symbol definitions passed in to the compiler on the command line (via /C:symbol=definition) to be lost.

972

1712.0.3

08 Mar 2022

clean up minor issues relating to spurious errors appearing after real prior errors.

971

1712.2.1

27 Feb 2022

new system function LSTRIP(strexp), or LSTRIP$(strexp), strips leading blanks from the specified string expression.

970

1712.0.1

28 Feb 2022

remove all special adjustments to the operator precedence rules in shortcut operator statements. This is an extension / cleanup of the change in 6.5.1708.1 (compiler edit 958) which restored the normal precedence rules for trailing USING operators.

969

1711.4.1

27 Feb 2022

fix bug causing a bogus syntax error on an expression involving a nested USING clause in a shortcut operator assignment. Bug was introduced in 6.5.1708.1 (compiler edit 958).

968

1711.3.1

23 Feb 2022

improve clarity of error messages relating to argument lists. Also close loophole allowing illegal parameter sizes to fail to trigger an error.

967

1711.2.1

22 Feb 2022

LSX file ++include indicators now show a <##_#> suffix indicating the sequential file # and the nesting level.

966

1711.1.3

17 Feb 2022

close window of opportunity for GPF associated with errors related to embedded DEFSTRUCTs.

965

1711.1.15

16 Feb 2022

include features mentioned elsewhere.

964

 

14 Feb 2022

 

963

1711.0.8

 

fix bug introduced in compiler edit 892 to support dynamic structures.

962

 

14 Feb 2022

 

961

 

 

 

960

 

 

 

959

1708.1.2

 

new auto-defined macro ABC_SCALE is set to the current SCALE value (0 if no SCALE statement yet encountered).

958

1708.1.1

27 Oct 2021

USING expressions on the right side of Shortcut Operators are now evaluated after the completed expansion of the shortcut operator statement.

957

1708.1.6

27 Oct 2021

DEFALIAS now updates the effective type (string or numeric) of the function, making it possible to alias a numeric function call to a string function or vice versa.

956

1708.0.5

21 Oct 2021

close a loophole that resulted in a bogus syntax error following an instance of an array base reference in an XCALL parameter list.

955

1707.3.1

21 Oct 2021

use of an automapped %m variable in the global context was resulting in a memory error at runtime.

954

1707.2.1

07 Oct 2021

close two loopholes related to the use of %x auto-mapped variables (see 1707.0 below) which were resulting in spurious compiler error messages.

953

1707.1.1

06 Oct 2021

MX_DYNSTRUCT DYNOP_DEF was not supporting .SIZEOF(var), resulting in a spurious error.

952

1707.0.2

04 Oct 2021

MX_DYNSTRUCT support: the default amount of work area memory allocated when defining (compiling) a dynamic structure has been increased from 128K to 2M.

951

1707.0.1

03 Oct 2021

auto-mapped variables are now confined to local contexts.

950

1706.3.1

03 Oct 2021

eliminate bogus "ambiguous relop" errors in nested control statements involving DYNSTRUCT references.

949

1706.0.2

28 Sep 2021

supports automapped %var variables.

948

1705.9.1

24 Sep 2021

automapped for/next loop variables (see 6.5.1704.0) were generating bogus compiler errors if there was a ++extern statement in the same function.

947

1704.1.1

05 Sep 2021

all standard string functions now support the optional $ suffix on the name (e.g. STR(x) or STR$(x).)

946

1704.0.1

10 Jun 2021

auto-mapped for/next loop variables. You may now create a new variable on the fly to act as the loop counter in a for/next loop by preceding the variable name with a %. See FOR … NEXT Control Structures.

945

1703.0.3

05 Jun 2021

eliminate spurious error complaining about the type or size of the record number parameter in a file OPEN statement if the parameter is part of a DIMX array.

944

1702.2.1

18 May 2021

generate error if non-F6 var specified in OPEN statement.

943

 

08 May 2021

 

942

1697.1.1

 

references in PRINT statements to entire arrays, such as PRINT .EXTENT(ARY()), were resulting in spurious syntax  errors.

941

1697.0.1

27 Jan 2021

WRITECD of an entire array.

940

1696.1.1

22 Jan 2021

close a loophole resulting in spurious "attempt to input from output only parameter" (or vice versa) errors in  SBXs.

939

1695.0.1

18 Jan 2021

new feature: "Implicit function return value capture". That's a mouthful to describe what is really a kind of "syntactic sugar" to  simplify referencing the result of a previously called function without having to map a variable and explicitly assign the value to it.

938

1690.3.1

10 Jan 2021

support a ++ifdef ... ++endif statement on a single source line.

937

1689.2.1

08 Oct 2020

arrays/collections may now be passed to DYNFUNC(), as they can in normal function references. Previously only  array elements were supported.

936

 

10 Sep 2020

 

935

1687.0.1

 

new dot variables:  .MILLITIME returns number of milliseconds since midnight, and .MICROTIME returns number of microseconds since midnight. a missing closing parenthesis on the end of a function parameter list wasn't always being flagged as a  syntax error. It was compiling as if the closing parenthesis had been there.

934

1686.0.1

17 Jul 2020

new unambiguous shortcut  operators:  #+= and $+=. These are equivalent to the existing shortcut  operator += except that they unambiguously specify either addition or concatenation, respectively, regardless of the destination type.

933

1685.0.1

02 Jul 2020

new dot variables: SBXNAME, SBXVERSION, CCYYMMDD, MMDDYY, DDMMYY, RECSIZ.

932

1684.0.4

01 Jul 2020

XOPEN now supports RANDOM and ISAM 1.x files. Also, XOPEN supports the option of expressing the flags argument as an expression rather than as a binary variable.

931

1684.0.2

12 Jun 2020

in programs compiled without the /X:2 or /RC switches, the memory storage assigned to the last explicitly mapped  variable was overlapping the first unmapped variables (assuming no /M). Problem was introduced in compiler edit 894 (A-Shell 6.5.1656.1)

930

1684.0.1

12 Jun 2020

the new SET'RECNO statement was causing a syntax error on a subsequent statement in certain contexts.

929

1683.0.5

12 Jun 2020

new ++PRAGMA FORCE_F1_HDR "<boolean>" may be used to toggle the /F1 switch. Use of the .ISNULL() function now sets the minimum runtime version to 1414.

928

1683.0.4

08 Jun 2020

updated to support various language enhancements.

927

1679.2.1

08 Jun 2020

STRSIZ 0 was causing spurious errors in some function declarations.

926

1676.1.1

14 Apr 2020

in programs compiled without the /M  (require all variables to be mapped) option, a reference to a non-existent  structure member (ST.MEMBER) within an otherwise defined structure (ST) was  resulting in the structure name getting auto-mapped as a F,6 variable.  

925

1673.2.1

06 Feb 2020

some variations of invalid DEFTYPE  statements were crashing the compiler.

924

1672.2

02 Jan 2020

revises edit 923 so that all ++ conditional compilation directives within functions and procedures are included in the LSX, even if within a function that has been shaken out by the /PX switch. Such conditionals may still be be relevant to how the rest of the file is compiled, and this resolves problems with conditionals that span the start or end of a routine.

923

1672.1

13 Dec 2019

incorrect minimum run version was written into object header in some cases. LSX file may have ended up with mismatched ++IF/++ENDIF if a conditional block straddled the function definition and the function was shaken out by the /PX switch.

922

1671.4.5

13 Dec 2019

attempting to use the .ISNULL() function with a non-string argument now generates an illegal expression error.

921

1671.0.5

05 Dec 2019

optimizes the runtime code generated by trace statements of the forms DEBUG.PRINT <args> and TRACE.PRINT (level,tags) <args>

920

1670.0.5

05 Dec 2019

the Minimum Run Version stored in the program header now distinguishes between two variations of the .CLEAR statement.

919

 

01 Nov 2019

 

918

1668.0.2

 

the Shortcut Operators += and -= now work with collections.

917

1665.4

19 Sep 2019

eliminate spurious "exceeded 512K limit" error on DATA statements when used in conjunction with some newer features.

916

1665.3.2

 

static functions which were called only by dynamic functions were getting shaken out of the tree by the /PX algorithm.

915

1665.2

30 Aug 2019

the presence of a single Dynamic function was disabling the /PX removal of un-called functions. It now only ensures that no Dynamic functions are removed, since we can't be sure if they are called dynamically.

914

1665.1.2

30 Aug 2019

add comment marker (!) to "{shaken out by /PX}" notations in the LSX file for ease of recompiling from the LSX.

913

1664.4.1

30 Aug 2019

TRACE.xxx statements were not allowing additional statements on the same line (using colon separators). Not that we'd like to encourage the anachronistic practice of jamming several statements together on a single line (presumably for the purpose of sharing a single THEN or ELSE clause), when it is much cleaner to use the multi-line IF/ENDIF construction. But technically it should be legal.

912

1664.3.2

11 Aug 2019

the /PX switch was causing .GLBI (and previously CMPGLOBAL.TMP) temporary files to be left behind.

911

1664.2.1

11 Aug 2019

the temporary file used to hold a GLOBAL_BEGIN/END block now uses a source-file-specific name <source>.glbi instead of the fixed name cmpglobals.inc. This resolves a conflict with running multiple simultaneous compilations in the same directory.

910

1663.0.1

11 Aug 2019

new ++pragma provides a way to assign a name to the LSX file that includes the vedit field of the program version: ++PRAGMA LSX_FSPEC "filespec" where "filespec" can be an A-Shell-style or native filespec, optionally including the following special macros:

909

1662.2.2

22 Jul 2019

compiler was failing to recognize the new LSX headers, causing total failure to be able to recompile LSX files.

908

1662.0.6

14 Jul 2019

fix failure to allow IFE() and IFE$() functions within relative expressions, e.g. IF IFE$(A$,B$) = C$ ...

907

1661.2

24 Jun 2019

.sizeof(var) was generating spurious variable not found errors for defstruct references in isolated cases. Introduced in compiler edit 902.

906

1661.1

06 Jun 2019

.sizeof(var) was generating spurious variable not found errors under a certain situations. Introduced in compiler edit 902.

905

1661.0.7

06 Jun 2019

new functional directive EXTERN(expr).

904

1661.0.5

06 Jun 2019

resolve an issue with MX_DYNSTRUCT in which source files with multiple DEFSTRUCTS containing MAP1 statements may have led to corrupted extents of array members of the target structure.

903

1661.0.3

06 Jun 2019

.SIZEOF() now supports DEFTYPE names, e.g. .SIZEOF(BOOLEAN).

902

1660.7.1

06 Jun 2019

.SIZEOF(VAR) was not respecting scope, (i.e. was finding global VAR when it shouldn't.)

901

1660.4.5

08 May 2019

IFELSE(relexpr,expr1,expr2), along with the IFELSE$() string version, were both treating the relexpr as being purely numeric, which after edit 890 was resulting in any string operands within the relexpr being converted to numeric prior to evaluation. This rendered string comparisons, e.g. A$ > B$ as being equivalent to VAL(A$) > VAL(B$), which had only about a 50% chance of giving the expected result.

900

1660.4.4

08 May 2019

in /X:1 or /X:2 mode, a FOR/NEXT loop was incorrectly starting from one STEP unit after the correct starting value if the initial expression ended with an operator with lower precedence than addition. For example, FOR I = X MAX Y TO Z was starting at (X MAX Y) + 1 rather than (X MAX Y) because MAX has lower precedence than the implicit addition or subtraction of the step value. The problem didn't affect the OCMPIL implementation of FOR/NEXT, and didn't occur if the 'from' expression was parenthesized. Same patch as 6.4.xxxx.

899

1660.4.3

08 May 2019

++PRAGMA GLOBAL_BEGIN wasn't working when the source file spec was longer than 50 characters—i.e. when using native filespec notation for the program source.

898

1660.0.2

08 May 2019

MX_DYNSTRUCT now allows DEFTYPE aliases for implicitly sized X variables. There were previously allowed, but the DEFTYPE name was lost during the runtime compilation.

897

1659

08 May 2019

fix for IFE() and IFE$() functions; original implementation didn't hold up when nested within other types of expressions, in particular IFELSE(). Note that the fix involves both the compiler and runtime.

896

1657.0.2

26 Mar 2019

compiler now embeds into the object header an indication of the minimum acceptable A-Shell runtime version, when certain newer language features are present. Runtime versions prior to 6.5.1657 will not recognize the new header signature and will treat the RUN as invalid (i.e. will refuse to run it). From this version on, the runtime system will recognize the minimum version header and will give a more precise error. Program requires minimum A-Shell level ####.

895

1657.0.1

03 Mar 2019

new functions IFE and IFE$.

894

1656.1.a

03 Mar 2019

close loophole in the ++PRAGMA TRACE_BEGIN logic that was resulting in spurious variable-not-defined errors in certain kinds of IF <expr> GOTO <label> statements where the <expr> involved a function call.

893

1656.0.2

27 Feb 2019

LSX Header now includes more detail.

892

1656.0.1

27 Feb 2019

add Explicit Comparison Operators.

891

1655.0.2

27 Feb 2019

new pragma ++PRAGMA AUTO_LARGE_CONSTANTS.

890

1655.0.1

14 Feb 2019

new operators and casting functions NUMEXPR, STREXPR, #+, $+ to eliminate the ambiguity in the + operator.

889

1651.8

14 Feb 2019

unmapped struct.member errors now display the full struct.member name. Previously it was only noting the structure name.

888

1650.0.1

18 Dec 2018

high level operations to Copy, Add, Subtract Collections (i.e. ORDMAP, ORDMAPM and MLIST structures) to/from each other.

887

1650.0.2

08 Nov 2018

++PRAGMA TRACE was generating spurious unmapped variable errors when encountering named parameter references inside function argument lists within certain kinds of statements (such as IF).

886

1649.0.4

08 Nov 2018

the ++IFMAP and ++IFNMAP conditional directives were always operating relative to the GLOBAL scope, rather than the scope (and extern rules) that would apply to the a variable in that context. For example, ++IFNMAP FOO within a function now checks for the existence of a variable FOO in the same way that a regular reference to FOO in that context would, i.e. considering a locally defined FOO, then a module private FOO, and then—if auto_extern or or ++extern FOO had been specified—a global FOO.

885

1648.1.1

22 Oct 2018

the first dynamic function compiled was missing the type,size attributes in the dynamic function index.

884

1647.4.1

04 Oct 2018

close memory corruption loopholes in the DYNSTRUCT compilation routines.

883

1647.2

30 Sep 2018

dynamic functions were unable to be located within RUN modules that were automatically recompiled with /A or /AV by the compiler due to the size. The .fn alias for the current function name was not working with private functions.

882

1647.0.4

30 Sep 2018

the Dynfunc mechanism now allows for retrieval of function return type information; see MX_DYNFUNC. TRACE.PRINT statements with the (level) and/or (level,tags) option were throwing bogus syntax errors for variations that weren't errors.

881

1647.0.3

30 Sep 2018

support .fn (case INsensitive) within a function as an alias for the function name variable. For example...

880

1647.0.2

30 Sep 2018

use of Ellipsis (...) in argument lists to facilitate passing arguments through a wrapper function.

879

1647.0.1

30 Sep 2018

language extension: Dynamic Function Calls.

878

1646.6.1

30 Sep 2018

revise compilation of ds.field(x) and ds.@fname$(x) to allow for better runtime error detection and handling. Incorrect use of ds.@fname$(x) in place of ds.@fname$(x)(y) can now be trapped at runtime with error 71, undefined dynstruct member. Any programs using DYNSTRUCT must be recompiled! Improve robustness of file-based MX_DYNSTRUCT DYNOP_DEF. Disable the auto-tracing—activated by ++PRAGMA TRACE_BEGIN—of MAP Statements with initializers, as this was leading to spurious errors. Fix spurious compiler error on IF <expr> RESUME <label>. Fix problem with ++PRAGMA TRACE_BEGIN appearing to have no effect after a previous ++PRAGMA TRACE_BEGIN at the same nesting level.

877

1646.1

15 Sep 2018

change syntax for indirect deferred dynstruct references from ".." to ".@" : ds.@fname  ! fname contains name of member (was ds..fname); ds.fname   ! fname is name of member (same as before)

876

1646.0.1

15 Sep 2018

the DYNOP_DEF operation in MX_DYNSTRUCT now supports reading the structure definition from ASB source files in addition to strings.

875

 

15 Sep 2018

 

874

1645.0.2

 

fix problem with CASE SYMBOL1...SYMBOL2 introduced in edit 870; Report any dynamic (S,0 or X,0) variable within a DEFSTRUCT as an error; Reset default trace level to 0, was 99 as of edit 871.

873

1645.0.1

29 Aug 2018

add dynamic structures.

872

1644.1

29 Aug 2018

the overall length of a ++PRAGMA statement was being incorrectly limited to 50 characters, which was mainly affecting TRACE_BEGIN. The new limit is 600 characters, with a max of 512 for the TRACE_BEGIN token-list—the fourth argument).

871

 

23 Aug 2018

 

870

1642.2.3

 

eliminate the ambiguity surrounding a defined symbol XXX when .XXX is an internally defined symbol—e.g. .TRUE. The problem was that the XXX was getting translated independently of the dot, resulting in unexpected results. For example assuming DEFINE TRUE = 1, a subsequent reference to .TRUE was returning .1 (substituting TRUE for 1 independent of the dot) rather than -1 (the built-in definition of .TRUE). Attempts to define symbols with leading dots are now considered errors, and references to symbols with leading dots consider only the dot version.

869

1642.2.2

15 Aug 2018

internal refinement to support the possibility of dynamically compiling defstructs at runtime.

868

1641.0.1

15 Aug 2018

PRIVATE variables and ++PRAGMA PRIVATE_BEGIN / _END blocks may now be used in the main source module to limit the scope of those variables to just that source file. Note that this enhancement entirely handled by the compiler; there is no issue with backwards or forwards runtime compatibility, even under AMOS.

867

 

03 Aug 2018

 

866

1639.3.4

 

fix some minor aesthetic problems with the auto tracing mechanism.

865

1639.3.3

16 Jul 2018

add private functions to the tags file for the benefit of APN and the Go To Definition script.

864

1639.3.2

16 Jul 2018

a DIMX array defined locally to a routine and then passed by reference to another routine was incorrectly getting deallocated return from the lower routine.

863

1639.2.2

16 Jul 2018

trace statements involving more than one comma-delimited term, of which at least one was a quoted string constant, where being formatted in a confusing way.

862

1639.0.7

16 Jul 2018

support the /NOTRC option (or -notrc when using the standalone compiler executable).

861

1639.0.5

16 Jul 2018

new ++PRAGMAs to support enhanced tracing ++PRAGMA TRACE_BEGIN   {optionlist}, ++PRAGMA TRACE.END     {optionlist}, ++PRAGMA TRACE.OPTIONS {optionlist}

860

1637.3.2

16 Jul 2018

compiler was failing to flag a syntax error for WRITECD and WRITETD statements lacking a comma or semicolon between each field.

859

1636.0.4

12 Jun 2018

the starting key in a FOREACH statement may now be any kind of expression.

858

1633.0.2

26 May 2018

very long FOR statements were potentially failing to compile correctly due to an overflow, without triggering a compiler error.

857

1631.1.2

15 Apr 2018

the /PX logic was failing to recognize a call to a function that was specified as the initializer to a MAP statement, thus opening up the possibility that the function would be removed, leading to a function-not-found error.

856

1631.0.5

06 Mar 2018

close a loophole that was allowing the compiler to go into an infinite loop in certain obscure cases involving unterminated literal strings with conditional compilation blocks.

855

1630.1.2

06 Mar 2018

SCALE: XPUTARG literal argument numbers and literal .EXTENT index numbers were not being scaled in the RUN file. The updated run-time system will now handle it either way.

854

1629

22 Feb 2018

add language feature: INPUT CSV into a Dynamic Array.

853

1628.1.2

15 Feb 2018

(a) XPUTARG @PARAM was not working properly with SCALE; (b) compiler now properly complains about a dangling comma at the end of a function/procedure parameter list. Previously such superfluous commas were ignored, but introduced doubt as to what the compiler was thinking.

852

1628.0.2

13 Feb 2018

increase maximum length of a single line of source code, including continuations, from 3K to 16K. Also increase the limit on the number of xcall / function / procedure parameters from 128 to 1024.

851

1628.0.3

13 Feb 2018

(a) /PX was not properly handling ENDFUNCTION statement with line numbers; (b) /P and /PX were not properly handling UNDEF statements; (c) built-in macros ABC_CURRENT_MODULE$ and ABC_CURRENT_ROUTINE$ were in some case returning garbage.

850

1626.0.4

13 Feb 2018

the patch in edit 848 for ++IFMAP and /PX now works for /P as well as /PX.

849

1625.1

30 Jan 2018

default function and procedure parameter values were not being respected in calls where no named parameters were specified. Problem was introduced in compiler edit 847.

848

1625.0.2

25 Jan 2018

(1) Passing a named lblref reference to a function without prefixing the name with @ was compiling but failing to actually pass the parameter. (2) ++IFMAP and ++IFNMAP now work as expected with /PX. Previously, since ++IF conditionals are processed during the initial pass but MAP Statements are not, a function that was only referenced within a block of code conditioned on a seemingly true ++IFMAP would get shaken out out of the tree, resulting in a function-not-defined error. This is now resolved. Note that ++IFMAP <var> only applies to global variables, not local or private variables.

847

1624.3.1

25 Jan 2018

fixes related to indirect/lblref functions:

846

1624.0.2

23 Jan 2018

.CLEAR enhancement: .CLEAR ARY() now supported for all types of arrays; previously it only applied to collections. The details of the clearing operation depend on the nature of the array being clear, described in further detail below.

845

1624.0.1

23 Jan 2018

STRSIZ-related refinements.

844

1623.0.1

23 Jan 2018

collections passing: Collections can now be passed by reference in an XCALL to an SBX

843

 

22 Dec 2017

 

842

1621.3.2

 

when using the /LF switch without /M, certain ++EXTERN ARRAY() statements for DIMX and ORDMAP arrays were generating spurious errors: unmapped variable or mismatched type/size.

841

1621.2.2

30 Nov 2017

the standalone Unix compiler was failing to process the -b and -l switches correctly. It was also failing to fold ++INCLUDE filenames to lower case if the compiler wasn't running from a directory mapped to a MIAME DEVICE.

840

1621.2.1

30 Nov 2017

certain references to a collection indexed by an array of structures, e.g. $coll(struct(i).member), within a FOREACH loop, were resulting in a spurious error on the NEXT $$i statement at the bottom of the loop.

839

1620.0.2

30 Nov 2017

symbol definitions passed on the command line using /C:sym=value were being ignored during the first pass of the /P and /PX processing. Also, the compiler macros ABC_CURRENT_ROUTINE$ and ABC_CURRENT_MACRO$ were in some cases creating an additional spurious macro "A" which might have caused a spurious syntax error for a variable "A".

838

1620.0.1

07 Nov 2017

add ASB Statement DEFALIAS.

837

 

07 Nov 2017

 

836

 

 

 

835

 

 

 

834

1616.0.2

 

support .ARGTYP(@arg) and .ARGSIZ(@arg). Concept is similar to that used for XPUTARG @arg (i.e. @arg is treated essentially as a macro for the argument number corresponding to the argument arg as defined in the function/procedure definition or as retrieved in an SBX using XGETARG(S).) No change to the runtime system required.

833

 

07 Sep 2017

 

832

 

 

 

831

1613

 

relax limitations on XPUTARG @VAR to allow the same parameter number to be associated with multiple variables, provided that the VAR the XPUTARG @VAR statement is never associated with more than a single parameter #.

830

 

 

 

829

 

 

 

828

1608.0.1

 

expand XPUTARG @argname mechanism (see 1607.0) to work for SBXs.

827

1607.4.3

29 Jun 2017

compiling with /P or /PX was resulting in spurious "undefined argument" errors in some cases when using the new XPUTARG @arg syntax. See 6.5.1607.0. When compiling with /PX and /LF, unreferenced functions and procedures ending with a two-part 'END' token—e.g. "End Function" or "END PROCEDURE"—were only writing the "END" to the LSX file, causing problems if the LSX was later compiled. The "{shaken out by /px}" line in the body of such routines in the LSX file is now properly commented out, allowing the LSX to be re-compiled without the /PX switch.

826

1607.0.2

21 Jun 2017

the maximum source code length of a function declaration was incorrectly set at about 512 instead of 3072 like all other source lines.

825

1607.0.1

21 Jun 2017

XPUTARG now supports the ability to reference the parameter to be returned by its name rather than by its number, using the following syntax:

824

1606

21 Jun 2017

certain DEFSTRUCT arrangements were generating absurd numbers of bogus syntax errors.

823

1605.1

 

the DEFSTRUCT/MAP1 enhancement added in compiler edit 821 was generally not working for ++include files; an illegal dot within a MAP or DEFSTRUCT variable name wasn't being reported.

822

1605

03 Jun 2017

language enhancement adds new Shortcut Operators VAR |= expr and VAR &= expr

821

1603

29 May 2017

 

DEFSTRUCT may now include a MAP1 statement as the first member of the structure.

 

The last entry in the table above, compiler edit 821 and A-Shell 1603, marked the beginning of the A-Shell 6.4 development cycle. At present, that marks the end of these notes. The list may be extended farther back in time at some point in the future. See the following topic for a second listing of compiler edits; it excludes bug fixes and overlaps somewhat with the list above, but it also goes back in time to 2013. For older notes on compiler changes and all A-Shell changes, you can also consult the A-Shell Development History documentation.