-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathNEWS
1452 lines (1201 loc) · 61.2 KB
/
NEWS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
r3120 (2023-09-10)
==================
About time to make another release. There are some fixes for reported
problems (thanks!) and for some more I've noticed myself. For new
features check below.
**Fixes**
* Line numbers didn't always show up in listing file when requested.
Was a regression, there was a workaround but it's not necessary now
* Listing file didn't listed labels at the end of functions/macros.
Now it does
* When .binclude failed it could cause an unexpected too many passes error.
No such surprises now on filename typos.
* Some versions of GCC miscompiled the source with LTO optimization
It resulted in an immediate crash at startup. It's worked around now.
* Possible issues fixed with (0, x) style indexed indirect addressing
This workaround should have been done more carefully. Should work now.
* When outputting a specific section the output was incomplete in some cases
I usually used complicated arrangements which worked so it was
surprising to find that in special a simple one it didn't
* Parsing errors could cause unnecessary undefined label errors
It does not do this any more, so less noise in error messages.
* Zero length concatenation of inverted bits/bytes was not correct
A very special case.
* The order of indirect parameters in format() was wrong (broke in r2345)
Haven't used it until now and was surprised to find this.
* The line number was at the wrong place in listing in some cases
Now it's always in front where it should be.
* There was a complicated way to cause a crash through encoding definition
One of those what would happen if experiments. Unlikely anyone
encountered this.
* Katepart syntax file was incompatible with newer version
There were silly mistakes in XML which were accepted in earlier versions.
* Possible crash fixed related to iterated bfor error handling
The error case handling had a mistake.
**Changes**
* .align and .page directives have offset parameters now.
It can be useful to shift the page windows up/down
* Listing time uses file modification times if possible
So the time stamp can remain the same across re-compilations
* Improved documentation
.page moved to the new alignment section. And lots of other fixes.
* Deprecation warning for non-spaced @b, @w and @l
It's planned that more than one letter will be used after the @ symbol
in the future. Once that's implemented any following non-spaced
separated label or number will become part of the symbol! So it's
advised now to add the missing spaces to avoid broken code after a
future upgrade.
**New**
* Added -Wpriority command line option
Common operator priority mistakes like >lbl1 != >lbl2 are reported now.
* Added -Walign command line option
Wasted space on doing alignments can be diagnosed now.
* Added .alignblk/.endalignblk directives
Alignment block for avoiding page crosses without wasting to many bytes
* Added .alignind and .alignpageind directives
It's now possible to align further ahead than the target location
* Added --simple-labels command line option
Label files in traditional label=$1234 style for simple parsing.
* Added --mesen-labels command line option
Experimental Mesen label file output.
* Added --labels-add-prefix command line option
When listing labels it's possible to add a prefix to symbols now
* Added --labels-section command line option
Label listing can be limited to labels pointing to a certain section.
* Added .from directive
For defining a symbol based on an already existing one somewhere else
* Added --dependencies-append command line option
For consistency.
* Added .elif directive
An alias for those who tend to mistype .elsif
* Added --c256-pgx and --c256-pgz command line options
Both are simple formats and a variant of existing ones.
* Binary and hexadecimal can be bits instead of int.
So format("%~#x", ~$2) is "~$2".
* Added --output-exec command line option
Now the execution address can be defined for those output which have
such concept
r2974 (2023-01-11)
==================
This is a bugfix release due to the broken multi file output. There were
a bunch of encoding related work meanwhile so these are included as well.
**Fixes**
* There was a mistake which could cause crashes (usually on Windows)
when outputting sections to multiple files.
* Linking to older versions of MS C library could result in unexpected
behaviour when Unicode characters were attempted to be output due to
differences to ISO-C. Such functions are not used anymore. The
precompiled binary used a recent enough toolchain and so was not
affected.
* Map file output not written to a file could still report a file open
error if the standard output was redirected and that couldn't be written.
* In some cases ANSI colour sequences could end up in text output to files.
This shouldn't happen now.
* Memory maps written to files were not added to makefile as outputs.
* The Notepad++ syntax file was incompatible with dark-mode as it set the
text background to white instead of transparent.
* When running on DOS the code page was not detected with some versions
of the OS.
* Attempting to use it on Windows versions without wide character
support resulted in immediate exit. Now it can be used as normal.
* When trying to use options with non-ASCII characters the error message
showed garbage.
* Coloured diagnostic messages only worked in console window but not in
mintty (unless compiled for Cygwin). Now it should work with the
native version as well.
* Depending on the C library memory map output could hang due to a
mistake. (e.g. on Amiga)
**Changes**
* On Windows the file encoding for "ANSI" files were assumed to use the
encoding from the current locale. However this can be different from
the active code page what text editors are using. Now such files are
assumed to use the active code page unless the locale is set differently
in the environment. Regardless UTF-8 sources are best for portability.
* On Windows text output (e.g. listing) was UTF-8 or ASCII depending on
the toolchain used. Now the default encoding is the active code page.
This can be UTF-8 on recent systems but in any case it can be forced by
setting an UTF-8 locale through the environment.
* Depending on C library version printable Unicode characters showed
placeholders even if the encoding would allow for it (e.g. UTF-8).
This is now determined internally to be consistent across platforms.
* The subset of Unicode characters usable in identifiers got more strict
now.
* Updated to Unicode 13.
r2900 (2022-11-05)
==================
It's time to release a version now. People are looking for fixes which were in
trunk for a long time now.
**Fixes**
* Paths with parent references don't give bogus portability warnings any more
On Windows the due to an oversight parent referencing paths incorrectly
triggered the portability warning originally intended for detecting a
filename case mismatch.
* Arbitrary length int right shift was wrong in some cases.
Now it's correct.
* .bfor didn't accepted .endfor closing in some cases
Now it's correct. Did always work with .next and I didn't transitioned the
test sources...
* (0, x) is now recognized as indexed indirect for opcodes
The parser of course did recognize (0,x) just fine for opcodes. However
writing (0, x) is a tuple and so does something else. There's a workaround
now to recognize such a construct as indexed indirect instead. This should
avoid bad surprises for those unaware that the indexing operator should not
have a white space there.
* Writing to standard output suppresses messages in all cases
This only worked for output files but now for everything (e.g. listing
to "-" didn't suppressed messages while --output "-" did).
* The TASM compatibility text macro parameter expansion was wrong
It didn't remove the quotes from strings. It broke quite long ago, now
works again.
* Output append didn't reproduce gaps working correctly in some cases
Padding was corrected and now it does.
* Output could have garbage in gaps on non-POSIX conforming systems
Unlikely anyone got that far in porting but gaps should be correctly
filled with zeros now
**Changes**
* JMP and JML are distinct now
JMP could be unexpectedly upgraded to JML in some cases (e.g. bank 0 address in
another program bank) which is bad as the program bank will be changed when
that happens. Now it's consistent with JSR/JSL.
* label = 1,2,3 is the tuple (1,2,3) now
That makes it actually useful for something. Before it was an object
with one couldn't do much with.
* .switch and .if blocks labels have size now
Everything else with regular code blocks worked that way already.
* %c in format() applies padding now
For consistency with the rest of the format parameters.
* Oversize integer diagnostic in bytes and bits now
It was in bits all the time but if the limit was set in bytes it makes
sense to give the error in bytes as well.
* Compound assignments can now change variables in parent scope
Without this using .bwhile is a pain as the loop condition variable is
usually declared out of the loop (and so the scope).
* The memory map was improved or at least is different now.
With the former memory map there were lots of redundancy if one used
sections. It was even worse with nested sections. The new memory map
tries to display overlaps more compact. However for most people with simple
projects the difference would be the length display in decimal on the left
and that gaps between data areas are shown now.
* Per output memory map, also writable to file.
The memory map was global before. Now if a specific section is output
then only the relevant parts of the map is shown. This also means that
if there are multiple output files then there are as many memory maps.
As a side effect .virtual blocks aren't displayed any more as these
don't really belong to an output file.
* The .enc directive now requires an expression
In the past one could write the name of encodings without quotes. Soon there
was a need to allow labels to hold a name so there was a warning to quote the
names for the past 5 years or so. Now that custom encodings can be assigned
to labels there's an even greater need to be able to use labels. Therefore
the old style unquoted encoding names will be now interpreted as labels and
will likely fail to be found. Please quote the old name or as a workaround
define the missing labels with a string of the encoding name (e.g screen =
"screen").
**New**
* .symbol in namespace
Now it's possible to check if a variable exists in a namespace. May be useful
to check if a variable is defined. No, this does not work with constant
definitions.
* Function parameter conversion
This allows to have a parameter like "data : binary" which calls
binary() and its result is assigned to the parameter. This allows to
load data relative to the caller's file and not relative to the file the
function is located in.
* !in and !== operator
Instead of !(a in b) now it's possible to write a !in b. Also the ===
operator got its !== pair.
* Multi operand opcodes do broadcast now
It was only working for single operand ones so far, now it's consistent.
* Bit strings can be iterated now
Just like character and byte strings did already
* ::= reassign operator
This can change a variable in parent scope. Unlike := which instead
would create/update a variable in the current scope instead.
* Better reporting of unexpected characters
Strings should be quoted with straight quotes. Using fancy quotes did
result in an error but it was difficult to make sense of it as the
difference is hard to spot. Now the diagnostic is more clear.
* --mos-hex for MOS Technology HEX format
There was Intel and Motorola before but not MOS yet. There are 6502 platforms
needing this.
* --list-append added
Now listing can be appended too, just in case.
* .encode/.endencode encoding area
This allows to have local encoding definitions. Such definitions can be
assigned to a label to allow reuse in other areas. Can be used as string
conversion function as well.
* Added .tdef for easier encoding definition
It was not easy to define translation for randomly scattered Unicode
characters so far as .cdef was made for ranges like A-Z. One had to
define a bunch of single character ranges but such a workaround can be
replaced now.
r2625 (2021-04-25)
==================
The last release got more than a year old now and there were
plenty of pending corrections to be released. Some planned
features still didn't made it in. Maybe next time.
**Fixes**
* .fill/.align multi byte pattern fix
Broke due to changes in r1845.
* Wrong diagnostic for incomplete byte string
The missing closing quote was pointed at the wrong place
* Incomplete diagnostic message
The opcode was not displayed in some cases
* Diagnostic locations fixed
In some cases the location was wrong
* Duplicate diagnostic messages avoided
In some cases redundant diagnostics was output
* Crash while .function declaration and macro init parameters
Found by Pierre
* Improved filename portability checks
In some cases case insensitive filenames were not recognized
* Diagnostics of non-portable filename characters improved
Now points at the problematic character.
* Functions did not execute as loop and other conditions
Now they do.
* Can't calculate errors related to functions
In some cases these were incorrectly reported
* 4510 missed had () instead of (),z addressing mode
Now same as 65CE02 in this regard
* Improved format() diagnostics
It's more strict now
* Floating point bitops didn't work as intended
Actually in some cases they did work but mostly not
* Dot eor operator works again in TASM compatible mode
Got broken due to syntax clash with hexadecimal floats
* Wrong message text for invalid unary operators
Tried to diagnose them like binary by mistake
* Improved syntax highlighting
In some case it didn't highlight well on vim
* Byte string compare didn't work properly
In case a byte string was inverted.
* In some cases .null failed to detect zeros
For example for ~$ff
**Changes**
* Comment nesting
Directives are not recognized now in commented block
* Negative size an error now, size extension a warning
If an offset reduces a memory area beyond 0 it's a fault now
(instead of 0) and extension beyond the original size a warning.
Controllable through -Wsize-large.
* PC bank wrapping gone now
Seemed like a good idea but crossing banks with long data gave
unexpected results for many people.
* VICE label de-duplication is gone now
Was intended to avoid warnings on import but actually breaks
symbolic breakpoints if the needed label gets deduplicated...
* -Wswitch-case gone now
Could cause unexpected side effects which is a no-no for diagnostics
* Ident renamed to symbol
For less confusing diagnostic messages
* Long values not displayed in listing by default
They cluttered up the listing. They are still displayed in verbose
mode.
* Dictionary keys must be identical and not equal
Otherwise bit strings can't be matched properly for example.
* Hex float format from format() gone now
Seemed like it's easy to add without much effort but it was not cross
platform.
* Bit string extraction operators now return bit string
Did return bytes for a long while but now I realized those may not
compare as expected in some cases.
* Multi line expressions are gone now
Seemed like a good idea back then but they cause more problems than
they solve. They were never documented due to all the unsolved edge
cases anyway.
* Duplicated label files do not append automatically
It must be done now explicitly with --labels-append
* Unnamed values not listed in listing any more
There's no label so makes no sense
**New**
* Immediate operand to branches
It's now possible to write 'bne #0' (for self modifying code)
* Hexadecimal byte string literal separation with spaces
Space is accepted now in hexadecimal byte strings like x'ab cd'
* Various byte string functions added
Like byte(), word() and friends
* New --output-append parameter
For appending the output to a file instead of overwriting it
* New --no-output option
For cases where no output file is needed
* Symbol definition syntax
May be defined with a dot prefix. Useful as dictionary keys.
* New .sfunction directive
For defining single line functions which only do calculations
* Alternative end directives
Bit more verbose but more consistent and easier to remember.
E.g. .endpage vs. .endp
* Identity operator (===)
For exact matching
* --no-error and --error-append
To not save or append error messages
* Broadcasting conditional operator is '??'
Sometimes broadcasting is needed but that's not compatible with the
regular '?' conditional operator
* Diagnostics for interrupted compilation
Now it's displayed where it happened for improved infinite loop
debugging.
* --labels-append
For appending to label files.
r2200 (2020-04-07)
==================
This is a bug fix release to fix the unintended performance degradation on some
systems like BSDs.
**Fixes**
* Revert buffering changes
These caused really slow performance on some systems which I forgot to test.
* Makefile name escaping
It's not the same as for shells and is more limited. So names with spaces
should work now but otherwise it's advised to avoid incompatible file naming.
* Bold black is not be visible on black background
Changed to cyan.
* Unicode parameter file names didn't work on some platforms
Forgot a conversion so only UTF-8 worked
**New**
* Coloured output on windows console and DOS.
This was available for a while but not for these platforms. Real DOS needs
ANSI loaded and TERM set.
r2176 (2020-03-23)
==================
There were quite many changes in trunk so it's time to release another version.
**Changes**
* Removed -Wtype-mixing
It was a transitional warning just in case someone relied on an undocumented
tuple/list mixing which changed earlier.
* Floor rounding is used by default now, added -Wfloat-round
The old method was to truncate but it was not consistent with the integer
division and was problematic when using floating point to represent
fixed point numbers. The difference only shows for negative numbers.
Just to be on the safe side there's a new warning now for cases where
the programmer could use one of the rounding functions explicitly to avoid
a rounding ambiguity.
* Handling of address space wraps in calculations
There are various address space wraps depending on the CPU. As an example the
zero page may wrap or may not with indexed addressing. 64tass now tries to
wrap when an offset is applied to an address to keep it in the same address
space. E.g. a label at $10 in the expression lda label-$20,x results in
lda $f0,x for a 6502 but lda $fffff0,x for a 65816. In all cases there are
warnings issued for such an ambiguity. If it's intentional it may be
suppressed but usually it's not.
* -Wmem-wrap and -Wpc-wrap renamed now to -Wwrap-mem and -Wwrap-pc
To make them in line with the other bunch of new -Wwrap-something switches.
Please update your build scripts. They won't fail just yet but may in future.
* Only --export-labels references labels
Listing labels incorrectly referenced .proc blocks and so just by doing a
label list unused .proc blocks got suddenly compiled in. This is unexpected
and should not happen for a simple label list therefore it won't any more. If
otherwise unused .proc blocks are needed in the label listing please add the
new --export-labels option to get them listed and compiled.
* Star is finally a label now
Before it was only a number but as the theory goes it should be the
memory location at the beginning of the line. This means label = \* + 1
constructs are now correctly referring to memory locations.
* Variables are not listed in VICE label list any more
They are ambiguous as may be assigned multiple times and usually don't refer
to memory locations
* Dictionaries are order preserving and iterable now
Earlier order was undefined.
* I/O error messages or in C locale now
As the rest of the messages aren't localized either.
**New**
* Add -Wmacro-prefix
Warns about macro calls without any prefix in front
* Add WDM opcode
It was requested for 65816
* Added .while and .bwhile
Could be done with .for before but it's cleaner this way
* Add .breakif and .continueif
Simplifies .if .break .fi and .if .continue .fi sequences
* Functions got a namespace
The function itself can hold symbols now so there's no need for an
additional label just to store data across invocations. That is
"functionname.stuff := 4" works now.
* Lists can be used as keys in dictionaries
On query they need to be put into a list of course
* CPA alias was added for CMP
For consistency with CPX and CPY.
* Added --macro-caret-diag
Normally the diagnostic message is displayed along with the line causing it.
There was an option to suppress the line display for those who don't want
this but that makes debugging of macro expansions hard as the source file only
contains the unexpanded macro. This option is a middle ground to display
faulty lines only for macros.
* Added --vice-labels-numeric
Normally only memory locations are included to avoid numeric constant
definitions in the listing but if you have a lot of label = $3000 style
definitions this is for you.
* Dictionaries are concatenable now
There was hack to add entries by using the splat feature but the simpler
{1:2}..{2:3} works now too.
* Dictionaries are sortable
Now that the order is preserved and they are iterable this makes sense
* Multiple output files can be generated now
By using multiple "--output" parameters. The output format and the section used
may be varied of course.
* Broadcast works with format() as well
It's now possible to format values in a list and the result is a list of
formatted values
* Added --make-phony command line option
This is useful for automatic dependency generation purposes for Makefiles.
* Added .with/.endwith
This allows to access symbols of another namespace without changing the
current one. Unlike .namespace/.endn which does that.
**Fixes**
* Now @b and @w works for branches
It can be used to prevent automatic long branches where it'd be bad
* Fix AHX/SHA mode
Wrong addressing mode was used
* Leading zeros warning message suppression was corrected
Due to a copy mistake it was -Wimmediate instead of -Wleading-zeros
* Improve double definition error handling
It worked before as well but caused so additional errors
* The "Too early to reference" error is gone now
Now nothing is to early to reference
* Listing now contains returned values
The results of function return values are in the listing now
* Unused .proc labels not in listing any more
If unused technically the don't exists and should not be there
* Improved macro diagnostic message position for macros
In many cases now the diagnostic messages are issued at the macro invocation
instead in the macro body. At least when it seems like the problem is due to
wrong parametrization.
* Addressing mode and size messages improved
They display the opcode now which can't have that addressing mode or size
* Diagnostic backtrace now omitted for trivial cases
This cuts back on the useless clutter for diagnostic messages in a multi file
project
* Inverse command line options added for consistency
For example there was a --quiet but no --no-quiet.
* VICE label lists omit duplicate entries now
The monitor can only display one of them
* Various diagnostic message location improvements
Some diagnostic messages pointed to the directive instead of it's parameter
* Functions may be created anywhere
There were limitations on where functions may be defined but it's sorted now.
* Struct offsets are numbers now
Of course they are but they were addresses earlier which caused -Wimmediate
to not trigger on them.
* In some cases a missing .ends was not reported
Now it is
r1900 (2019-02-17)
==================
Quick bug fix release to sort important regressions for file numbering, label files and \*=/.offs.
**Fixes**
* File number in line numbered list file was wrong
The parent was shown instead (which is not very useful)
* Empty data or code lines vs. --no-source
Empty data lines are omitted now from the listing file
* Undefined symbol messages could be wrong in macros
In some special cases it ended up as garbage
* Open/close directives shouldn't work across files
Still worked with .include and the result was confusing
* VICE label file generation crash on unconvertable address
In the unlikely case like 0,x and similar
* .offs now does what C64 TASM does
This fixes a regression for old-school \*=/.offs relocations
r1864 (2019-02-03)
==================
This release took a while as I wanted to test some of the features in practice
first and those projects took a lot of time. Also some parts had to be
rewritten as the implementation wasn't quite right. Then in the testing phase
I've found a lot of problems and I wanted to solve them before doing a release.
Anyway it's finally out now and I think it's a good improvement over r1515. If
not then please let me know.
**New**
* Add -Waltmode to show unavailable addressing mode fallback
Data bank addressing may be bad sometimes instead of direct page
* Add ".for var in sequence" style iteration loops
Looping over lists elements got easier now
* Add .namespace/.endn directives
Now it's possible to switch to namespaces temporarily
* Add -Wno-page
Now the .page/.endp error can be turned into a warning or off
* Add --output-section
Output can be limited to a specific section instead of dumping everything
* Add binary() function
This enables reading file content as a byte string for easier processing
* Add .virtual/.endv
For compiling to an address but without producing any output
* .align works in structures now
It aligns from the start of structure
* Folding operator "..." added
Summing, minimum, maximum, etc. of list elements is easier now.
* @w and @b size override now works with immediate addressing
For consistency, this is more useful for 65816
* Hexadecimal representation of byte strings x"1234"
More straight forward to type than bytes($3412) and with "proper" ordering
* z85 style byte strings representation z"0S\*"
More compact than x"1234". For label files and to embed binary data in source as text.
* Add .bfor and .brept
Scoped variant of .for/.rept which handles non-anonymous labels better
* Conditional assignment ":?=" added
Creates a new variable when symbol undefined otherwise keeps old value
* Lazy fault handling
A failed calculation is not a problem if the result is not used
* Negative .binary offsets
To allow offsets based from end of file
**Fixes**
* Data directives (.byte) must have at least one argument
Confusing behaviour, no argument is likely a mistake
* Missing closing directives didn't auto close
This resulted in confusing error messages or worse
* Improved directive missing messages
It's not just "something is expected" but a bit more verbose
* Undefined sections could cause too many passes
Implementation bug
* Optimizer suggestions are not shown for macros
How to apply multiple suggestions for a single line?
* Exported symbols (-l) were reported as unused
They are used for exporting after all...
* Compilation failed due to wcwidth
Some platform had interesting defines preventing compilation
* Improve unused checks
Was not reporting correctly in some cases (like macro invocation)
* Compilation warning reported by Compyx
A static keyword was missing.
* Sometimes compilation ended too early
In some sections related cases not enough passes were made
* Describe the "command line from file" feature better
A single paragraph was not enough
* Improved missing macro argument message
The old one was not verbose enough
* Redundant compilation warning (#33)
Didn't delete enough ;)
* Section end with union
Section end was not right in union
* Anonymous labels vs. conditional compilation
Make clear in documentation how this works
* 65CE02 stack relative addressing fix
Unlike a 65816 it's signed.
* VICE label generation was not generic enough
Some members where not listed.
* Improved -Wshadow
Due to the .namespace directive it was not good enough any more
* WIN64 compile fixes
Some format strings are unavailable on mingw64
* Incorrect warning about labels not on left
Colon suffix was not enough
* str()/repr() improvement
Some types have better string representations now
* Wrong type messages replaced with better conversion messages
The old message was not too helpful
* 65CE02 long branch fix second try
There were still cases where the wrong distance was calculated
* Structs and unions didn't instantiate using a dot
It was documented but didn't work
* Update to Unicode 11
Upgraded tables to the latest version
* Suppress repeated caret lines in messages
One is enough if all the others are the same
* .dstruct/.dunion double message on not defined
No additional syntax error message any more
* Improve error positions
Still some errors were not on the right character in line
* Only report file errors once
It's enough to know once if a file is missing
* Improve syntax error messages
Mostly replaced by 'expected' messages now
* Some messages lacked spacing at the end
Now it's there
* Indexing precedence fixed
Broke in r1315, oops.
* Faster in-place operations
Most noticeable for list appending or concatenate
* Anonymous labels vs. scopes
Now they're truly bound to scope like normal labels
* Runaway macro/function recursions are stopped faster now
Certain recursion faults were difficult to debug
* Wrong negated bit string shifting
~%10 << 1 was ~%100 instead of ~%101
* Wrong negated byte string
-x'00' was ~x'ff' instead of x'00' (integer value different)
r1515 (2017-05-01)
==================
It's about time to release another version as many changes were done and people were waiting for fixes already sitting in trunk for a while now. Some ideas didn't made it into this version as the implementation would have delayed the release even further, maybe next time.
Changes since the last version:
**Compatibility**
I'm not happy about these "annoying" changes and hope it's easy to update the affected code.
- Deprecation of '^' operator
Code needs to be updated to use the format("%d", value) function for converting
values to decimal strings. The reason is that the "standard" use of this
operator is to return the bank byte in almost all other 65816 assemblers. This
function is available with the grave accent operator currently, as '^' was
already taken at the time. Plan is to migrate to the standard variant. Old
code with '^' for decimal strings conversion will of course still compile now.
- Deprecation of non-string encoding names
The original ".enc" directive used symbols for identifying encodings. The
problem with this is that it's not parametrizable so the encoding can't be an
expression or variable. There was no other way back then as strings were not
supported at the time but it would be nice to allow such use. In this version
the encoding names may be quoted for future compatibility but no expressions
are available yet otherwise not yet updated code wouldn't compile.
**New**
Please check the manual for further details.
- Keys without values in dict (sets)
For quicker "in" than in list
- Compound assignment also in .for
Now "+=" and friends work in ".for"
- Add &&= and ||= compound operators
For consistency.
- Check for file name portability issues (-Wno-portable)
On multi platform development file names can cause compilation problems
- Find unused labels with -Wunused
Some unused labels may remain in code which can be pointed out
- Check inconsistent symbol references with -Wcase-symbol
For case insensitive but case matching symbols
- Add <? and ?> operators (smaller/min, greater/max)
New operator for range limiting
- Check for double .case values with -Wswitch-case
Multiple use of case value does not compile multiple times and may be a problem
- Check for missing # with -Wimmediate
For checking numeric constant opcodes without a '#' which may be a typos.
- Turn on a check with -Werror=xxx too
Less options needed as -Werror=xxx assumes -Wxxx.
- Command line arguments from file with @file
Frequently used options may be stored in a file
- Scopes and addresses included in VICE label listing now
Now more symbols are available in VICE
- Listing of labels of specific scopes only into files (--root-labels=)
Exporting of symbols only in a particular scope is possible now.
- Dict indexable with lists now
For translation uses
- Improve some error messages by displaying the invalid values
So that there's less guessing what the wrong value was
- Keep integers when rounding
floor() and friends converted to float unnecessarily
- Add sort() to sort lists
For sorting
- '-' can be a variable as well
For consistency.
- Optimizer warns about ror/rol which could be lsr/asl
C is clear, so there's no point shifting it in.
- Warn for float comparison problems -Wfloat-compare
Float comparisons may be wrong, especially for equality due to limited precision
- format() improvements (integer precision, etc.)
Some format() features were missing or wrong.
- Predefine pi constant
In case rad(180) needs too much typing...
- Assign function parameters as variables instead of constants
So that they may be modified.
- Check for leading zeros -Wleading-zeros
There's no octal number support, so this may be an error
- Check for aliases with -Walias
For consistent use of opcodes.
- Improve message of const as variable
It was a bit confusing
- Improved non-negative message on range errors
Make clear that the problem is with negative numbers not with number of bits
- Notes for common pitfalls -Wpitfall
Tips for some commonly encountered "problems".
- Long branch warnings are possible again -Wlong-branch
Long time ago this was there but was temporarily removed due to internal changes
- Optimizer warns about constant results, duplicate sir/sac
Calculations with constant values are pointless
- Optimizer proposes use of stz on 65c02
Storing zero, so why may use the specific instruction for that as well
- Update to Unicode 9.0
Including width tables this time
- Optimizer proposes use of bra
For always taken conditional branches
- Better out of memory error handling
For common cases it shows now where it happened.
**Fixes**
- Fix a few error positions which were missing
Some error messages still didn't point to the cause...
- Reduce fault messages for .endu/.ends
Too many messages
- Fix a possible null pointer crash for unknown address (fuzzed by Pierre)
Implementation bug
- Fix possible crash root namespace copying (fuzzed by Pierre)
Implementation bug
- Fix no argument indexing crash (fuzzed by Pierre)
Implementation bug
- Crash while handling struct values (fuzzed by Pierre)
Implementation bug
- Some special section nesting is not allowed (fuzzed by Pierre)
Implementation bug. The fix caused some regression but it should be fixed as well.
- Wrong memory use on long division (fuzzed by Pierre)
Implementation bug
- Missing type checks at a few places (fuzzed by Pierre)
Implementation bug
- Fix some return leaks
Return where not freed
- Compile fixes with VS
Compiles now with newer VS without messing with code
- Display address without mode correctly
Did not display that an address is an address
- Some notes were still displayed without warning/errors
Some suppressed messages still had their notes displayed
- Stdin/stdout not to be listed in makefiles
Pointless to do so, they are not files.
- Improve operations on addresses
Especially needed without mode
- Implement code offsets
To preserve code reference
- More operations on gap
For .struct defaults with calculations
- Fix integer limit checks
It was done wrong.
- Correct function call from macro line
Didn't work well.
- Fixed scoped macro highlighting in vim syntax
Was not handled in the syntax file
- Fix error messages on undefined section
Messages were wrong.
- Fix display of colon list with defaults
It was wrong.
- Unnecessary bytes needed message after another error
Duplicate message for something which is not there
- .eor was not applied to all fields in listing
Listing showed the wrong hex values except for the opcode
- label \*=\*+1 works again with warning -Wstar-equal
Broke when compound operators were added, now works again.
- Unpack code in .text
Inconsistent behaviour
- Fix some negative truncations/non-negative only values
Some negative values didn't supposed to be truncated.
- Restore bold output after invalid char inverted output
Bold was missing after inversion.
- Colours for all messages
Command line parameter errors didn't had it yet.
r1237 (2016-09-07)
==================
Just a quick bug fix release this time.
Due to a mistake in the previous version file errors were not reported at all most of the time, which was of course not the intention. This is the main reason for this release.
Otherwise only the encoding related error messages were improved to be less confusing.
r1229 (2016-07-09)
==================
Lot's of changes lately and not just code tidying ;) So it's about time to release another version.
** Changed **
There's a new deprecation warning for the old single '=' equal operator which might hit many as a surprise. If possible please update all instances to '==' as this is how it's written for many years now. If that's not an option then the warning can be disabled with the "-Wno-old-equal" command line option.
The recently added "--shadow-check" option was renamed to "-Wshadow" be consistent with the other new warning control options. This needs to be manually updated in build scripts. As it's a warning now by default a "-Werror=shadow" might be needed to make it an error again.
** Fixes **
* Fix highlighting of .sint in syntax files
* Memory leak in -M generation
* Bool \*\* was wrong due to a typo
* Negative integer modulo/division fixes
* Possible leak at label file generation
* Wrong function compare due to a typo
* pow() was wrong due to copy-pasting
* Reject overlong UTF-8 sequences
* Reduced the identifier set to used scripts
* 65CE02 relative long branch calculation corrected now
* Error out if the address mode is to complex
* .dsection didn't took over PC type
* Some calculations didn't work with addresses
* Weak variables were included in shadow check
* Data bank addressing was accepted incorrectly for some opcodes
* Text width of wide characters is correct now
* Exit code was wrong if output failed
* Disassembly of bit addressing instructions was wrong
** Improved **
* Improved key error message
Now displays what key was not found, not just says it's wrong
* Improved source portability and documentation
Hopefully it's easier to compile it now for some environments.
* Some out of memory errors are non-fatal now
Now for these few memory errors the diagnostic is a bit better.
* Improved floating point highlighting in some syntax files
It's including the dot and exponent as well if possible.
* Indexing can be subtracted now
It was not possible before unless it matched.
* Bits and bytes negation preserves size unless on overflow
These are not converted to integer any more just because of negation.
* Better error message for small address space "bank crossing" and bank 0.
Some of those 65816 style messages were not appropriate for small systems.
* Improved fault handling strategy (no early exit and false messages)
Due to early exit some invalid fault messages were displayed, and sometimes important messages were hidden. This should be better now.
* Repeated data lines are shortened now in listing file
The listing file will be not overly long now just because there was a .fill 8192,0
** New **
* "Column indexing" of nested lists
This is quite cool but hard to explain here ;) But there's a section called "Slicing and indexing" now in the manual where this is shown as well.
* New CPU type for 4510
For the MAP and EOM opcodes, otherwise the same as 65CE02.
* Line numbers in listing, column headers (--line-numbers)
It's possible to enable an additional column for line numbers and source origin. So that it's easier to find what's coming from where (especially macros).
* Strict boolean operations (-Wstrict-bool)
New warning for finding implicit boolean calculation
* Warning for deprecated operators (-Wdeprecated)
It warns about things like using '=' instead of '==' before it's too late...
* Colored error messages on some systems
Colored diagnostic messages are displayed on some terminals now
* Optimizer warnings (-Woptimize)
There's an experimental optimizer now, which can generate useful warnings sometimes.
* Some additional addressing modes for NOPs for R65C02/W65C02
To be consistent with the NMOS 6502. After all these NOPs are at least defined in the data sheets ;)
* Scoped variables are now output in VICE labels
Now scoped variables are included in VICE listing, which can help debugging a lot.
* Add --cbm-prg command line option just for completeness
It's the default, but now it has an option anyway.
* Use NOP immediate and relative long for skipping if available
New possibilities to skip bytes and words using the "gxx" pseudo opcodes on some CPUs.
* Syntax highlighting for VIM
It was about time. Not the same what I use normally, for a good reason ;)
* Signed immediate addressing mode (lda #-1)
After long last it's possible to enter negative numbers for immediate addressing as a proper signed version was introduced. See manual for notes (#- and #+)
* Warning for implied addressing instead of accu (-Wimplied-reg)
To find code where the "a" was left off "asl".
* Diagnostics switchable now and can be made to an error (-Wxxx).
There's more control now over what gets warned about and how. See the "Diagnostic options" section in manual for details.
* Display command line option at the end of warnings/errors for switchable ones
Many warnings are switchable now so it's good to know what switch can be used to manipulate them. These are displayed in brackets after the messages.
* Option for jump bug warning (-Wjump-bug)
The jmp ($xxff) warning has an option now
* Option for address wrap warnings (-Wpc-wrap, -Wmem-wrap)
Address wrap warnings have an option now
* Option for label not on left warning (-Wlabel-left)
The check was improved to have less false positives and has an option now.
* Option for branch page crossing (-Wbranch-page)
These are quite common and hard to do much against, so it's not enabled by default.
* Option for old '=' operator warning (-Wold-equal)
This checks for the old single equal operator, which should be changed to '=='.
r1050 (2016-04-30)
==================
Some time passed again, so here's another release: