Releases: fermarsan/aixt
aixt0.1.8
v0.1.7
v0.1.6
New features:
- Standardize the basic data types as V
- Add a typedef declaration for each compiler type in
.json
file (remove the necessity to do code replacements) - Give support to "type" aliassing
- Add a custom attribute for defining constants and functions as C macros in order to save memory in small devices
- Define API modules' parameters as constants
- Allow implementation of the same Module on multiple directories
v0.1.5
0.1.4
v0.1.4
2 Oct 2024
New features
Different versions of match
statement were implemented:
- regular
match
;- With one or multiple identifiers or literas
- With one or multiple Infix expressions (comparisons)
- With one or multiple ranges
- assignment by
match
:- With one or multiple identifiers or literas
- With one or multiple Infix expressions (comparisons)
- With one or multiple ranges
Thematch
statements for enums are not allowed yet.
v0.1.3
v0.1.2
Devices Supported
Devices updated to API v0.1.1
- Software emulator
- PIC16F8x family
- Arduino Uno
- Arduino Nano
- ESP32-DevKitC
- Raspberry Pi Pico
New features
- Compile option was turned into more universal behavior by using pseudo variables inside .toml files
- API modules can be written in both
module
andmodule_complement
folders - API implementations can be reused by similar ports or devices calling them from the .toml
- Generate C templates for most of the Aixt's V expression and statements using
$tmpl
v0.1.1
Aixt V language
Now Aixt V is closer to original V due to:
- All the variables are immutable by default. mut reserved word is fully supported.
- Only a few C pre-processor directives are supported (#include)
- C macros are avoided
- The Aixt API is implemented mainly in V
- Reference variables are supported
- Interoperability with C is improved by allowing the calling of C functions, constants and variables by using the syntax:
C.function()
orC.identifier
, previous including the correspondent C header file
declaration/initialization by function calling directly
Changes:
- The pin names and modes don´t include the module's name so pin.setup(pin.d5, pin.output) changes to pin.high(d5, output), this change is for been less redundant.
- All the variables are immutable by default. If a mutable variable is needed, the use of mut reserved word is imperative.
- Variables can be declared/initialized by calling a function directly, so this two lines:
a := u16(0)
a = adc.read(an5)
can be replaced by:a := adc.read(an5)
- Solve some issues with Makefiles.
API standardization
The function names were standardized for these modules:
pin
: individual pinsport
: pin portsadc
: analog to digital converterpwm
: pulse width modulationuart
: serial porttime
: delaying functions
Configuration .toml
files
Now the configuration files are split by device-settings and compiler-settings in different .toml
files, in order to reuse and make it easy to include similar devices.
Supported devices
Emulator
Software emulator on Linux, Android (Termux) and Windows (x64-based or AArch64-based device: x64 or AArch64), using GCC or TCC compilers.
Microchip
PIC16F8x family
- PIC16F83
- PIC16F83A
- PIC16F84
- PIC16F84A
Arduino boards
- Arduino Uno
- Arduino Nano
The rest of devices or boards have to be migrated from API v0.0.1
v0.1.0
Aixt V language
Now Aixt V is closer to original V due to:
- All the variables are immutable by default.
mut
reserved word is fully supported. - Only a few C pre-processor directives are supported (#include)
- C macros are avoided
- The Aixt API is implemented mainly in V
- Reference variables are supported
- Interoperability with C is improved by allowing the calling of C functions, constants and variables by using the syntax:
C.function()
orC.identifier
, previous including the correspondent C header file - declaration/initialization by function calling directly
Changes:
- The pin names and modes don´t include the module's name so
pin.setup(pin.d5, pin.output)
changes topin.high(d5, output)
, this change is for been less redundant. - All the variables are immutable by default. If a mutable variable is needed, the use of
mut
reserved word is imperative. - Variables can be declared/initialized by calling a function directly, so this two lines:
a := u16(0)
a = adc.read(an5)
can be replaced by:a := adc.read(an5)
API standardization
The function names were standardized for these modules:
pin
: individual pinsport
: pin portsadc
: analog to digital converterpwm
: pulse width modulationuart
: serial porttime
: delaying functions
Configuration .toml
files
Now the configuration files are split by device-settings and compiler-settings in different .toml
files, in order to reuse and make it easy to include similar devices.
Supported devices
Emulator
Software emulator on Linux, Android (Termux) and Windows (x64-based or AArch64-based device: x64 or AArch64), using GCC or TCC compilers.
Microchip
PIC16F8x family
- PIC16F83
- PIC16F83A
- PIC16F84
- PIC16F84A
Arduino boards
- Arduino Uno
- Arduino Nano
The rest of devices or boards have to be migrated from API v0.0.1
Aixt 0.0.1
v0.0.1
Supported Modules:
- ADC
- PWM
- GPIO
- UART
Supported Devices:
-
Emulator on Linux, Android (Termux) and Windows (x64-based or AArch64-based device: x64 or AArch64)
-
LEGO Mindstorms NXT (NXT Intelligent Brick: AT91SAM7S256 (ARM7TDMI) "nxc backend")
-
Microchip
- PIC16F84A (Delay, GPIO)
- PIC16F676 (Delay, GPIO, ADC)
- PIC16F873A
- PIC16F886
- PIC18F452
- PIC18F2550
- Explorer 16: (PIC24FJ128GA010 )
-
Atmel
- MH-Tiny: ATtiny88 "arduino backend"
- Arduino nano: ATmega328p "arduino backend"
-
Seeed Studio
- Seeed Studio XIAO SAMD21: ATSAMD21G18 (Cortex-M0+) "arduino backend"
-
LogicGreen
- LQFP32 MiniEVB: lgt8f328p "arduino backend"
-
Espressif
- NodeMCU V3 Lua: ESP8266 (LX106) "arduino backend"
- ESP32-C3FH4 Core Board (WeAct Studio): ESP32-C3 (RV32) "arduino backend"
-
ST
- Blue Pill: STM32F103C6 (Cortex-M3) "arduino backend"
-
LuatOS
- CORE-Air32F103CBT6: air32f103 (Cortex-M3) "arduino backend"
-
Raspberry Pi
- Raspberry Pi Pico: RP2040 (Dual Cortex-M0+) "arduino backend"
- Raspberry Pi Pico W: RP2040 (Dual Cortex-M0+) "arduino backend"
-
Ai-Thinker
- Ai-WB2-32S-Kit: BL602 "arduino backend" (Delay, GPIO, PWM, UART)
Backends:
- c
- arduino
- nxc
V language features not supported yet:
- OOP (functions associated to structures)
- match keyword
- inmutable variables by default (mut keyword unsupported)
- declaration/initialization by function calling
- dynamic memory