Skip to content

Latest commit

 

History

History
182 lines (158 loc) · 12 KB

CHANGELOG.md

File metadata and controls

182 lines (158 loc) · 12 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog and this project adheres to Semantic Versioning.

TODO

Changes that are planned but not implemented yet:

  • Add ability for an instruction to have order agnostic operands. That is, instr a, b is the same as instr b, a. This allows swap to occupy less instruction space.
  • Enable instruction aliases that allow alternative mnemonics for an instruction. For example, allowing call and jsr to mean the same thing.
  • Improve error checking:
    • Disallowed operands
    • missing : after labels
    • unknown labels
    • Disallow instructions on the same line as an .org directivexy
  • Add named label scopes. This would allow a label to be defined in a specific scope that can be shared across files.
  • Create a "align if needed" preprocessor directive paid that generates an .align directive if the bytecode in between the pair isn't naturally on the same page and can fit on the same page if aligned. An error would be benerated if the block of code can't fit on the same page regardless of alignment.
  • Update the #ifdef and related preprocessor directives to include detection of labels and constants.
  • Allow multiple cstr defininitions on the same line
  • Upgrade python version requirements to 3.11
  • Fixed a bug where embedded stringsd weren't properly parsed if they contained a newline character or there were multiple embedded strings per line
  • Fixed a bug where parsing properly discriminate between labels starting with BYTE string and the BYTEx() operator.
  • Fixed a bug in generating the syntax highlighting configuration that caused mnemonics with special characters to not be highlighted properly.
  • Added support for The Minimal 64x4 Home Computer with an example and updated assembler functionality to support it.
  • Added address operand type that enables several features specific to absolute addresses, include slicing the address to support "short jump" type instructions.
  • Added .align directive to align the current address to a multiple of a given value.
  • Changed syntax highlight color theme name to be specific to the language rather than the generic "BespokeASM Theme" name.
  • Added optional support for embedded strings in the assembly code. When enabled, strings can be ebdedded in the code withou a data directive such as .cstr. This is enabled by setting the allow_embedded_strings option in the general section of the configuration file to true.
  • Added ability to mute byte code emission with the preprocessor directive #mute and unmute with #unmute.
  • Improved handling of include directories by duplicating and normalizing all search paths.
  • added .asciiz as an equivalent data directive to .cstr
  • Updated Github workflow to add Python 3.11 to the test matrix.
  • Remove usage of deprecated aspects of Python importlib library so that the code will work with Python 3.11 without deprecation warnings.
  • Fixed reported bug where indirect indexed register operands were not parsed properly.
  • Fixed bug that did not sanely handle an instructions operand configuration indicating 0 operands
  • Allow predefined constants to labels starting with _, which also indicates file scope for code defined labels
  • Added The Minimal 64 Home Computer example
  • Added support for negative values in numeric expressions, data type initializations, and constant values
  • Improved several compilation errors.
  • Added ability to create preprocessor macros/symbols with #define directive. Thes macros can then be used in code. Also added the ability to define preprocessor symbols on the command line and in the instruction set configuration file.
  • Added conditional assembly preprocessor directives tht act on preprocessor symbols:
    • #if
    • #elif
    • #else
    • #endif
    • #ifdef
    • #ifndef
  • Added the ability to set the cstr terminating character. It default to 0, but can be set to another byte value.
  • Added support for using character ordinals in numeric expressions. For example, 'a' is the same as 97. Only valid for single character strings using single quotes.
  • Allow expressions to be used in data directives. For example, .byte 1 + 2 is the same as .byte 3.
  • Improved error messages for a badly configured configuration file.
  • Added the listing pretty print format, replacing the legacy default pretty print format.
  • Corrected workflows bug
  • Improved error messaging
  • Added indexed_register operand type. Similar to indirect_indexed_register, but it does not imply the address dereferencing.
  • Changed the instaltion method to use the modern pyproject.toml approach.
  • Added ability for an numeric operand that is ostensibly an address to be checked to be a valid address value per the GLOBAL memory zone. Uses the valid_address option in the argument setting for an operand. Only valid for numeric, indirect_numeric, deferred_numeric, and relative_address operand types.
  • Added checks to ensure memory zones are defined within the GLOBAL memory zone.
  • Allow instruction configuration to only contain a variants list.
  • Added example for the MOSTEK 3870
  • Added example for Intel 8085 processor
  • Addressed some bugs in how macros are handled.
  • Added syntax highlighting to differentiate macros from native instructions
  • Added operand decorators to some operand types. This allows for some semantically differentiated notation, for exmaple, here ++ is the decorator: [sp]++
  • Added hexadecimal format indicated by a trailing capital H. For example 08FH would be a hex value for $8F.
  • Added ability to use EQU to assign constant label values in addition to =.
  • Changed use of byte_code to bytecode in instruction set configuration file. THIS IS A BREAKING CHANGE
  • Fixed bug where unknown instructions did not produce an error.
  • Fixed bug where #include directives did not recognize otherwise valid file names
  • Fixed bug where zero operand macros did not get recognized correctly
  • Added ability to reverse the order of the byte code that an instruction's operands emit.
  • Added the relative_address operand type.
  • Added more examples
  • Added named memory zones feature.
    • As a result of this addition, the "memory block" feature was renamed to "data block" to further distinguish the two features.
  • Made instructions case insensitive
  • Added example for the slu4 Minimal UART CPU System
  • Added more pretty print formats and the ability to select them
  • Added support for more than one instruction per line in the assembly source. There are some limitations. See documentation.
  • Added support for MSB and LSB unary functions in expressions
  • Added instruction macros feature
  • Started using pipenv for dependency management.
  • Fixed bug for numeric enumeration operads that emit a argument value.
  • Added .8byte data type directive
  • Fixed bug in how complex expressions are parsed in certain directive arguments
  • Added bit shifting operations to expressions
  • Fixed a bug in handling registers named b, which is also the binary number prefix
  • Allow a label to exist on the same line as an instruction or directive
  • Fixed a bug in how compiler defined constants were handled
  • Fixed and improved syntax highlighting for language extensions
  • Added some snippets
  • Improved error handling
  • Added KENBAK-1 example
  • Added deferred_numeric operand type. Its intended to be used as a "double derefence" type operand (the value is at the address value contained at the address numeric value given)
  • Added enumeration and numeric_enumeration operand type that creates byte code and argument values based on a key/value pairs. enumeration uses string keys, and numeric_enumeration uses integer key values reesolved from a numeric expression.
  • Added numeric_bytecode operand type that converts the operand numeric value into byte code subject to a bounds check. Useful for bit index type operands that are really different instructions based on value.
  • Added the ability for operand byte code contributions to prefix the instruction byte code as opposed to suffixing it.
  • Added instruction byte code suffix that appends the byte code after the operand byte code is added to the base byte code.
  • Added origin option to general section of configuration that sets the initial origin address for compilation. Defaults to zero.
  • Added support for predefined constants and memory blocks with labels that can be used at compile time.
  • Added examples for the KENBAK-1 retro-computer.
  • Fixed language version checking
  • Added syntax highlighting for escape characters in strings.
  • Improvements to Visual Studio Code language extension generation
  • Added ability to generate a language package for Sublime Text editor
  • Enabled directive arguments to be numerical expressions
  • Added ability for source code to indicate what ISA version it needs to be compiled with.
  • Added ability to generate a language extension with syntax highlighting for Visual Code Studio
  • Added indirect index register addressing mode.
  • Fixed a bug in parsing binary numbers assigned to constants
  • Added .cstr data type to be a null-terminated .byte blob, or a C-style string.
  • Made .byte and .cstr data created by strings honor python-style escape sequences in the strings.
  • Added improved error checking:
    • Ensures indirect register operands with an offset are properly configured.
    • Ensure that labels do not use directives or key words
  • added some error checking on the configuration file
  • added support for local and file scoped labels. Local labels start with a . and are only valid between two non-local labels. File scope labels start with a _ and are only valid within the same file they are defined.
  • added error that detects when register labels are used in numeric expresions.
  • added the ability to #include other asm source files when compiling a given source file.
  • Added the concept of instruction variants to the ISA model configuration. Instruction variants allow a specific operand configuration for an instruction to generate wholely different byte code, such as a different prefix value.

0.1.4

First tracked released

  • Enabled the reverse_argument_order instruction option be applied to a specific operand configuration. This slightly changed the configuration file format.
  • Added ability for instructions with operands to have a single "empty operand" variant, e.g., pop