home *** CD-ROM | disk | FTP | other *** search
/ AMIGA PD 1 / AMIGA-PD-1.iso / Programme_zum_Heft / Programmieren / Kurztests / DiceC / version.doc < prev   
Text File  |  1994-02-01  |  18KB  |  473 lines

  1.                    VERSION.DOC
  2.                   DICE
  3. VERS DES COMMENT
  4.     VERS    = Release Version
  5.     DES     = bug fixed / feature designator
  6.     XB  - major bug fixed in main compiler
  7.           (use of routine in question could have caused a crash)
  8.     B   - minor bug fixed in main compiler
  9.     F   - feature added
  10.     E   - enhancement to existing feature
  11.     O   - optimization added
  12.  
  13.     ADD - feature added or fixed that is standard C but was not previously
  14.           implemented or working.
  15.  
  16.     XBL - major bug fixed to library
  17.     BL  - minor bug fixed to library
  18.     FL  - feature added to library
  19.     OL  - optimization added to library
  20.  
  21.     XBA - major bug fixed in support program (i.e. not DCC or sub programs)
  22.     BA  - minor bug fixed in support program
  23.     FA  - feature added to support program (or new support program)
  24.     OA  - optimization added to support program
  25.  
  26.     COMMENT = comment or bug, feature
  27.  
  28. 2.06.37
  29.     B    arrays are now aligned the same as their element type
  30.     alignment.  Thus, char a[3]; is byte aligned while short a[3];
  31.     is word aligned. Previously arrays were always word aligned.
  32.     (not really a bug, but required to work with Amiga cia structures)
  33.  
  34.     F    PROFILING ADDED.  New -prof option to DCC, LIBMAKE, and FDTOLIB.
  35.     This tool gives you unmatched profiling capabilities.  You may
  36.     profile just your source, standard C calls, amiga library calls,
  37.     or any combination.  A <programname>.dprof file is automatically
  38.     generated when your program exits and may be turned into a
  39.     textual representation    with the DPROF program.
  40.  
  41.     Profiling routines have a 1 uS granularity under 2.0, 20 mS
  42.     granularity under 1.3.
  43.  
  44.     __noprof qualifier for procedures added -- prevents a procedure
  45.     from being profiled (used by the system to prevent the profiler
  46.     routine from getting profiled itself)
  47.  
  48.     F    C.LIB renamed to CS.LIB to generalize library names.  Infix IDs
  49.     are now generalized as follows:
  50.  
  51.     L   large data model
  52.     S   small data model
  53.     R   registered args, else stack args (registered release only)
  54.     P   profiled, else not profiled.
  55.  
  56.     DCC will now use the -prof and -md/-mD options to determine which
  57.     c.lib and amiga.lib to use.  The more useful combinations are
  58.     included in the distribution and registered users may make
  59.     additional versions as needed.
  60.  
  61.     Note that you may mix options -- it is perfectly valid to compile
  62.     source modules with -mD but link small-data.
  63.  
  64.     BL    bug in fread() fixed relating to an fread() occuring after an
  65.     ungetc().
  66.  
  67.     E    ALL LIBRARIES IN THE SYSTEM REORGANIZED.  There are now many
  68.     more libraries.  Registered users now have a means of remaking
  69.     *ANY* library from scratch by unpacking the library source code
  70.     and typeing 'dmake' with no arguments for instructions. Generally
  71.     only the DTMP: assignment and -2.0 in your DCCOPTS is required.
  72.  
  73.     Since there are many more libraries possible then I can fit in the
  74.     distribution, this means may be used to create esoteric libraries
  75.     that the majority of people will never use.
  76.  
  77.     F    Fixed two major bugs with constant floating point arithmatic...
  78.     addition and subtraction would not work correctly in a few cases
  79.     (it would get the sign wrong), the exponent would get screwed up
  80.     in some cases (usually after a negation), and I was overflowing
  81.     the single-precision exponent range for conversions to type float.
  82.  
  83.     Ooooo this stuff should have been caught long ago!
  84.  
  85.     F    Fixed a pointer arithmatic bug, yet another case where a scratch
  86.     register would get overwritten due to a procedure call.
  87.  
  88. 2.06.36
  89.     B    register allocation bug fixed, related to floating point
  90.     routines mainly.  Would generate a 'Too many redos' error
  91.     in some cases (bug did not generate bad code).
  92.  
  93.     F    PRECOMPILED INCLUDES ADDED, see -H option in DOC/DCC.DOC.
  94.  
  95.  
  96. 2.06.35
  97.     FL    under 2.0 (V37), getenv() now checks for local enviroment variables
  98.     before global ENV: variables.  Under 1.3 only global ENV: variables
  99.     are checked for.
  100.  
  101.     BL    fixed %U and %W in strftime(), would generate incorrect week-of-year
  102.  
  103.     B    fixed stringize operator for \n, i.e. quoteme(fubar\n) -> "fubar\n",
  104.     would previously generate incorrect result (I think)
  105.  
  106.     B    fixed bugs in integer multiply & divide, some cases would generate
  107.     fatal errors (all caught by DICE)
  108.  
  109.     B    fixed bug &= operator, would generate assembly error in
  110.     conditional:    while (x &= (x - 1)) ...
  111.  
  112.     F    optimizations made to mulitply & divide, handles 16 bit expressions
  113.     better.
  114.  
  115.     F    minor optimization added for procedure calls within the same
  116.     module.  If call is within a byte offset then BSR.B will be
  117.     used, else BSR.W is used.
  118.  
  119.     F    DLink now checks for illegal small-data references to far objects
  120.     and generates the appropriate error message.  This was added for
  121.     completeness and also because __far or -mD data objects are no
  122.     longer A4-relative.  The check will catch illegal model mixing.
  123.  
  124. 2.06.34
  125.     BL    bug in <varargs.h> (old style var-args) fixed, was skipping first
  126.     argument.  Note that all ANSI projects should use <stdarg.h>
  127.  
  128. 2.06.33
  129.     B    bug in offsetof(type, array_elm) fixed, previously caused error
  130.     message.
  131.  
  132. 2.06.32
  133.     B    fixed bug in dlink Introduced in .31 that would cause a machine
  134.     crash.
  135.  
  136.  
  137. 2.06.31
  138.     B    fixed floating point bug relating to array indexing, would
  139.     clobber A0 in some cases
  140.  
  141.     B    fixed preprocessor bug relating to the use of hex constants
  142.     in #if expressions (they wouldn't work)
  143.  
  144.     E    redid the handling of the ?: routine to allocate its result
  145.     storage (a temporary register) after running the sub-expressions
  146.     instead of before, which allows you to nest ?: indefinitely without
  147.     generating an too-many-redos error.
  148.  
  149.     B    register allocation bug (would generate fatal error) in
  150.     &array (redundant & operator) has been fixed.
  151.  
  152.     B    DCPP now accepts null directives.  # with no directive.
  153.  
  154. 2.06.30
  155.  
  156.     F    DCPP now evaluates undefined symbols in #if expressions as 0
  157.     instead of generating an error message, as per ANSI.
  158.  
  159.     B    Yet another bug in the # (stringtize) operator found.  Fixed.
  160.     Really really really should work right this time!
  161.  
  162.     B    bug in switch/case fixed, case <enumid>: would generate an
  163.     error message.
  164.  
  165.     BA    I was shipping the wrong mathieeedoub*.library shared libraries,
  166.     would cause erronous float->double conversion.
  167.  
  168.     B    another floating point bug found in && and || of the
  169.     form 'fp && fp' or 'fp || fp', would cause incorrect
  170.     evaluation and/or assembly error
  171.  
  172.     B    small bug in fread() would sometimes set error flag
  173.     when returning EOF, and fseek() would not reset this
  174.     flag (it does now).
  175.  
  176.     BL    bug in *scanf(), %c would overwrite the char by one byte
  177.     (i.e. store into two chars instead of one).  fixed.
  178.  
  179.     B    DCPP didn't handle a quoted /* in directives correctly.
  180.  
  181.     F    Large programs that have more than 64K of *initialized* data
  182.     may now use either __far for selected items (preferable) or -mD
  183.     without causing link errors.  Previously dlink would combine far
  184.     data along with near data making all small-data referenced bss
  185.     items out of range if more than 64K of initialized data had been
  186.     declared, __far or not.  Now, DC1 generates 'fardata' sections
  187.     properly when -mD or __far is used (previously only worked with
  188.     __far), and dlink will not combine any section name beginning with
  189.     'far' into the small data model.
  190.  
  191.     This is only of major import when compiling incredibly huge
  192.     programs.  Note that having greater than 64K of bss with -mD or
  193.     __Far has always been supported since library bss is always forced
  194.     in front of program bss.
  195.  
  196.     F    DLink now takes approximately 15% less memory.    While it still
  197.     requires memory to hold the combined size of all objects and
  198.     libraries, incidental memory requirements now reuse much of this
  199.     memory from unlinked sections instead of allocate new memory.
  200.  
  201. 2.06.29
  202.     B    another long standing bug found: short a = i * j; where i and j
  203.     are long's and *also* a memory reference (not in regs),
  204.     the multiplication short-result optimization was screwed up.
  205.  
  206.     B    register allocation bug (would produce a fatal error) fixed,
  207.     registers would not be deallocated in constant conditional
  208.     expressions such as:    1 ? (a = 4) : b;
  209.  
  210. 2.06.28
  211.     B    really dumb bug fixed, made retroactive to 2.06.27 (all 2.06.27
  212.     dists were redone with this fixed).  Had been introduced in 2.06.27
  213.  
  214. 2.06.27
  215.     E    add -// option to DCC and DCPP, enables C++ style // comments.
  216.     If not specified, // style comments are ignored.  Generally
  217.     one puts -// in DCCOPTS.
  218.  
  219.     E    added -no-env option for DCC.  If specified, DCC will *not*
  220.     load options from DCCOPTS.
  221.  
  222.     B    fixed bug:  static int fio(), fio();  (procedure declared twice
  223.     on same line) would force procedure to be non-static.
  224.  
  225.     fixed bug:  __geta4 int fio(), bar(); ... __geta4 would apply
  226.     only to first procedure.
  227.  
  228.     B    fixed bug w/ labels ...  label: case ...  would generate error
  229.     message (case or default following directly after label).  Was
  230.     introduced when I initially fixed labels.
  231.  
  232.     E    AUTO-AGGREGATE INITIALIZATION ADDED, e.g.
  233.     main() { int a[] = { 1, 2, 3 }; ... }.
  234.  
  235.     static & global initialization has been re-vamped.  Note that
  236.     bit-field aggregate initialization is NOT supported yet.
  237.  
  238.     B    Fixed bug that has been in there from the beginning.
  239.     int *a; a[20000] = 1; ... would not multiply the constant by 4 to
  240.     get the index.    ONLY EFFECTED CONSTANT INDEXES WHOS OFFSET WOULD BE
  241.     LARGER THAN A SIGNED SHORT, which is why it was not caught.
  242.  
  243.     B    Fixed bug in float point stack allocation... temporary fp variables
  244.     from the previous procedure would not properly be cleared from the
  245.     cache, causing erronous stack offsets (that overlap other variables)
  246.     in the next procedure.
  247.  
  248.     E    Added ANSI 'U' extension for constants, e.g. 123U.  DICE now
  249.     automatically promotes a constant to unsigned if it does not fit in
  250.     a signed long, such as 4000000000.  Note, however, the int->float
  251.     conversion is currently always signed due to lack of
  252.     unsigned->float calls in the amiga's shared fp libraries.
  253.  
  254.     B    small bug in fread(), would not set the EOF flag when an EOF
  255.     occurs for an fread() requesting a buffer size larger than the
  256.     stdio buffer size.
  257.  
  258.     B    when making a registered-args call (-mr, -mR, -mRR) where a
  259.     pointer - int subtraction occurs, i.e. foo(ptr - int, int),
  260.     arguments after the argument containing the ptr - int would
  261.     be incorrect (registers would get squashed).  ONLY applies
  262.     to registered-args calls.  This has been fixed!
  263.  
  264.     B    bug in preprocessor fixed, #define fubar(x) "a x a" would replace
  265.     the 'x' in the string, which is wrong.
  266.  
  267.     B    bug with bitfields has been found and fixed.  Essentially, bitfield
  268.     operations in routines that need to run a retry pass can get
  269.     munged.  This is usually caused by routines that declare lots of
  270.     local variables.
  271.  
  272. 2.06.26
  273.     B    Fixed bug in floating pt compare of the form:  x = (f1 == f2);
  274.     i.e. a compare where the result is a boolean 0/1 when not in
  275.     a conditional.    Was caught by DICE (caused a fatal error).
  276.  
  277.     B    Fixed bug w/ bitfields (was caught by DICE), would give fatal
  278.     error if destination was not a register for field extraction.
  279.  
  280.     B    fixed bugs with stringtize operator in macros, should now work
  281.     according to the ANSI spec.
  282.  
  283.     #define fubar(x) #x
  284.  
  285.     BL    month was off by one for %m operator in strftime()
  286.  
  287.      E    PROCEDURES MAY NOW RETURN STRUCTURES.  YOU MUST PROTOTYPE ALL SUCH
  288.     PROCEDURES.
  289.  
  290.      E    added // comments to DCPP (C++ style comments)
  291.  
  292. 2.06.25
  293.     E    doc/errors.doc now exists, error handling centralized.
  294.  
  295.     E    a printer driver and exec device driver example has been added to
  296.     examples/ ... so now I have a shared library example, dos device
  297.     driver example, EXEC device driver and printer driver example.
  298.  
  299. 2.06.24
  300.     B    stack allocation changes in 2.06.23 were broken, broke floating point.
  301.     (got the stack tracking mixed up w/ variable allocation)
  302.  
  303.     B    ?: fix in 2.06.23 was broken (sigh), fixed ... 'default:' would
  304.     not be properly tokenized.
  305.  
  306.     E    *scanf() now supports %e/E/f/g/G and %[..]
  307.  
  308. 2.06.23 BETA
  309.     B    goto labels are now in their own name space, no more conflicts
  310.     with  int a; ... goto a; ... a: ...
  311.  
  312.     F    added stack tracking for fp temporaries, meaning that subroutines
  313.     containing floating point expressions do not take up anywhere near
  314.     the amount of stack they used to.
  315.  
  316.     F    allows declarations after switch() { and before first case.
  317.  
  318.     F    fixed problem with  ... ? symbol : ...    (symbol was being
  319.     interpreted as a label instead of a variable within a ?:
  320.     conditional
  321.  
  322.     F    fixed problems with conditional returns from fp operations,
  323.     such as:    double a, b; int c = (a < b);  that must
  324.     generate a 0/1 result instead of a branch (as in an if()).
  325.     Would generate error before.
  326.  
  327. 2.06.22
  328.     B    fixed problem with GOTO labels, a goto label semantically is
  329.     not a statement unto itself.  The problem is a line like the
  330.     below:
  331.  
  332.         if (i) j = 1; else x: j = 2;
  333.  
  334.     Currently j = 2; is completely outside the if in DICE.    This
  335.     is incorrect,  'x: j = 2;' counts as a single statement.
  336.  
  337.     E    libmake is now documented, it wasn't before!  New options have
  338.     been added to libmake and fdtolib.  For libmake, DCC's -D
  339.     option has been added.    For fdtolib, a new -p option is specifiable
  340.     to set the prefix used on exported symbols (to support creation
  341.     of dynamic.library compatible object modules)
  342.  
  343.     B    fixed bug in string constant array initialization,
  344.     char x[1] = "a";  previously generated an error
  345.  
  346.     B    fixed infinite ERROR printing loop
  347.  
  348.     F    revamped constant-address handling (i.e. when you map a
  349.     complex structure over IO space at a known address, useful when
  350.     generating ROM'd apps for 68000 based uP's.
  351.  
  352.     F    dynamic.library & support routines now part of the distribution.
  353.  
  354. 2.06.21
  355.     E    fixed register reallocation, should now do a better job
  356.     allocating registers in complex subroutines.  Hopefully squashed
  357.     'maximum retries exceeded' error for all but the most incredibly
  358.     complex expressions.
  359.  
  360.     B    fixed bug in int->float conversion, expressions such as:
  361.         double x = (double)(a * b);
  362.  
  363.     E    fixed somestuff that generated an infinite WARN loop.
  364.  
  365.     F    DCC now creates the destination directory heirarchy if it does
  366.     not exist.  For example, when you DCC com/x.c the object file
  367.     will be T:com/x.o, with T:com created if necessary.
  368.  
  369.     F    DYNAMIC FUNCTION/VAR LIBARARY SUPPORT ADDED, see __dynamic
  370.     explanation in DYNAMIC.DOC .
  371.  
  372.     F    DCPP now accepts -Ddefine(vars..)=definition, it used to be
  373.     able to only accept -Ddefine=value
  374.  
  375. 2.06.20
  376.     F    TimerBase, for timer.device library calls, now has auto-open
  377.     capability, meaning that you can simply call AddTime(), CmpTime(),
  378.     SubTime(), and the new 2.0 calls (GetSysTime() & ReadEClock())
  379.     without having to open the timer.device and set up TimerBase
  380.     yourself.
  381.  
  382.     B    bug in if (ptr & 1) and similar constructs doing a logical and
  383.     in a compare against a pointer rather than an int produced
  384.     bad code caught by DAS.
  385.  
  386.     B    x.o was in c.lib, this is wrong... x.o must be the LAST file in
  387.     any link and is included automatically by DCC when it runs DLINK.
  388.  
  389.     F    additional example code in DCC2:examples -- a DOS handler and
  390.     a shared library.
  391.  
  392. 2.06.19
  393.     B    bug in dynamic stack code under 1.3 fixed
  394.     B    bug in workbench startup under 1.3 fixed
  395.     B    bug in register allocation fixed (would cause fatal error
  396.     message 'too many retries' sometimes when procedure args
  397.     declared as arrays instead of pointers)
  398.  
  399. 2.06.18
  400.     F    several more libraries have auto-open capability
  401.  
  402.     B    bug in DLINK fixed -- would GURU on large links due to an error
  403.     in the allocation routines (relocation info larger than 4K would
  404.     cause a GURU)
  405.  
  406. 2.06.17
  407.     F    DCPP now scans DINCLUDE:PD/ for include files.    This is where I
  408.     will be putting .H files for various ports (such as the UNIX
  409.     regexp port).  This was done so as not to clutter the main
  410.     DINCLUDE: and to differentiate between PD files and non-PD
  411.     files.
  412.  
  413.     UNIX compatible .H files are usually placed in DINCLUDE: or
  414.     DINCLUDE:SYS/
  415.  
  416.     F    preprocessor now handles #if defined(symbol) properly (was
  417.     previously not implemented)
  418.  
  419.     F    BITFIELDS now 99% implemented!    including signed/unsigned
  420.     qualifications.  The only thing that does not work is ++bitfield
  421.     and --bitfield.  Single-bit bitfields have been optimized.
  422.     aggregate initialization of bitfields is still wanting.  executable
  423.     actually got smaller when I finally got down and fixed these up.
  424.     No 020/030 support yet.
  425.  
  426.     F    startup code modified to allow writes to desc 0, reads from desc 1,
  427.     etc...    at the file descriptor level but not the stdio level.  This
  428.     is to support some UNIX programs which do this.
  429.  
  430.     BL    bug in [f]putc() fixed -- [f]putc() is supposed to return the put character,
  431.             but did not do so in the case of a new line (putc), or
  432.             at all (fputc).
  433.  
  434.     F    NEW LIBRARY ROUTINESE:    stat(), fstat(), getenv(), opendir(),
  435.     readdir(), closedir(), rewinddir() (see MAN/UNIX.DOC)
  436.  
  437.     F    chdir() now restores the original directory on exit
  438.  
  439.     F    Dynamic Stacking added (-gs option).  Somewhat primitive, but will
  440.     get much better.  This allows subroutines to be as deeply nested as
  441.     required, allocating and deallocating stack frames when low stack
  442.     conditions exist.
  443.  
  444.     F    longjmp()/setjmp() now properly handle dynamic stacks
  445.  
  446.     B    fixed another bug, this one having to do with the index address
  447.     mode (An,Dn.x) combined with a binary operator.
  448.  
  449.     B    fixed bug in FDTOLIB that screwed up register ordering.
  450.  
  451. 2.06.16
  452.     B    fixed EXG bug in DAS, EXG As,Ad would generate Ds,Dd.. screwed
  453.     up registered args (-mRR).
  454.  
  455.     B    fixed bug in *= and /= combined w/ array indexing, things like
  456.     temp[i] /= 23; would use the scratch regs for storage across
  457.     the divide call.
  458.  
  459. 2.06.15
  460.     F    BASIC REGISTERED ARGUMENTS ADDED.  See -mr, -mR, and -mRR options
  461.  
  462.     F    prototype optimization.  If a prototype says a procedure takes a
  463.     short, then DICE pushes a long (as usual).  However, DICE will
  464.     no longer EXT the object before pushing it (upper word is garbage).
  465.     This works because the procedure, having declared the argument a
  466.     short, will only access the lower 16 bits.
  467.  
  468.     B    fixed token pasting bug in dcpp, a ## b ## c now works properly.
  469.  
  470.     F    first registered distribution that includes the 2.0 includes,
  471.     restructuring of 1.3 includes (now called 'amiga13' instead of
  472.     'amiga'), and restructuring of disks to make more space.
  473.