I miei computer, console e programmi retro
Amstrad CPC
Compilatore Z80 VI
02/01/2023 17:10
Un'altra manciata di giorni e ho aggiunto gli Array, per il momento mono-dimesione.
Sia stringhe che numerici e i comandi per usarli sono ANEW, APUT e AGET.
Al momento ogni elemento di un array di numeri occupa due byte perché uso word ma
un array di stringhe occupa 256 byte estremamente esoso per un Amstrad CPC.
Sto pensando, in fase di creazione con ANEW, di poter dichiarare lo spazio massimo in byte
per elemento in maniera da ridurre il consumo di memoria.
Anche perché in questo esempio mi partono 2 interi KByte.
Come anche nel caso di PROC/FUNC il valore viene restituito tramite le variabili
globali _Value e _Value$ come succede per "it" in Livecode.

Sia stringhe che numerici e i comandi per usarli sono ANEW, APUT e AGET.
Al momento ogni elemento di un array di numeri occupa due byte perché uso word ma
un array di stringhe occupa 256 byte estremamente esoso per un Amstrad CPC.
Sto pensando, in fase di creazione con ANEW, di poter dichiarare lo spazio massimo in byte
per elemento in maniera da ridurre il consumo di memoria.
Anche perché in questo esempio mi partono 2 interi KByte.
Come anche nel caso di PROC/FUNC il valore viene restituito tramite le variabili
globali _Value e _Value$ come succede per "it" in Livecode.

Compilatore Z80 V
30/12/2022 12:25
Un'altra manciata di giorni e il compilatore cresce un'altro pochino.
Ora c'è la struttura di controllo IF/ELSE/ENDIF su più righe (alla faccia del Locomotive Basic) e
in più è possibile nidificarli. La parte più complicata, se posso dire così, è stato scrivere il codice Z80
per ogni tipo di confronto usando i salti jr ed ottimizzare il più possibile con le label.
Inoltre nel esempio uso il nuovo comando FUNC/ENDFUNC e il ciclo FOR/NEXT
Tanto per controllare che continua a funzionare tutto hahahahaha

Ora c'è la struttura di controllo IF/ELSE/ENDIF su più righe (alla faccia del Locomotive Basic) e
in più è possibile nidificarli. La parte più complicata, se posso dire così, è stato scrivere il codice Z80
per ogni tipo di confronto usando i salti jr ed ottimizzare il più possibile con le label.
Inoltre nel esempio uso il nuovo comando FUNC/ENDFUNC e il ciclo FOR/NEXT
Tanto per controllare che continua a funzionare tutto hahahahaha

Compilatore Z80 IV
10/12/2022 12:13
Credevo di scrivere molto più codice in Livecode per implementare due nuovi fondamentali comandi PROC/ENDPROC FUNC/ENDFUNC
Invece con una buona analisi, con un pugno di righe, ecco qui due istruzioni fondamentali:
case "PROC"
case "FUNC"
if gaProc[v_Token2]["Nome"] = v_Token2 then
xAbort "[ERROR] PROC/FUNC already declared"
else
put v_Token2 into gaProc[v_Token2]["Nome"] //Aggiungo il nome della procedura all'elenco
put 0 into gaProc[v_Token2]["NParametri"]
put true into gProcedura //Indica al output che si sta generando una procedura
xOutPut v_Token2&":" //Nome_procedura:
repeat for each item tVar in v_RestoTesto2
add 1 to gaProc[v_Token2]["NParametri"] //Incremento il numero di parametri
put (tVar) & comma after gaProc[v_Token2]["Parametri"] //Aggiungo
xSeNonEsisteCrea tVar,,True //Crea una variabile per ogni parametro esistente
end repeat
end if
break
case "ENDFUNC"
case "ENDPROC"
xOutPut "ret"
put false into gProcedura
break
Ovviamente poi nella fase di generazione del codice Z80 ci sono tutte le dichiarazioni delle variabili/parametri
distinguendo tra variabili testo e numeriche. Oltre alla valorizzazione della variabile di ritorno per le variabili.
Come da mia idea iniziale li dati di ritorno delle funzioni sarò contenuto nelle variabili globali _Value e _Value$
come succede per "it" in Livecode.
Invece con una buona analisi, con un pugno di righe, ecco qui due istruzioni fondamentali:
case "PROC"
case "FUNC"
if gaProc[v_Token2]["Nome"] = v_Token2 then
xAbort "[ERROR] PROC/FUNC already declared"
else
put v_Token2 into gaProc[v_Token2]["Nome"] //Aggiungo il nome della procedura all'elenco
put 0 into gaProc[v_Token2]["NParametri"]
put true into gProcedura //Indica al output che si sta generando una procedura
xOutPut v_Token2&":" //Nome_procedura:
repeat for each item tVar in v_RestoTesto2
add 1 to gaProc[v_Token2]["NParametri"] //Incremento il numero di parametri
put (tVar) & comma after gaProc[v_Token2]["Parametri"] //Aggiungo
xSeNonEsisteCrea tVar,,True //Crea una variabile per ogni parametro esistente
end repeat
end if
break
case "ENDFUNC"
case "ENDPROC"
xOutPut "ret"
put false into gProcedura
break
Ovviamente poi nella fase di generazione del codice Z80 ci sono tutte le dichiarazioni delle variabili/parametri
distinguendo tra variabili testo e numeriche. Oltre alla valorizzazione della variabile di ritorno per le variabili.
Come da mia idea iniziale li dati di ritorno delle funzioni sarò contenuto nelle variabili globali _Value e _Value$
come succede per "it" in Livecode.
Compilatore Z80 - III
02/12/2022 18:28
Da qualche giorno, nelle mie ore libere da impegni, ho ripreso il progetto del compilatore Z80.
Il nome provvisorio è NOBasicCompiler e l'unico target, per il momento, è l'Amstrad CPC.
Mancava però una procedura per salvare e ripristinare lo schermo.
Alle volte la semplicità è la strada migliore in 10 righe ecco qui le due funzioni:
_RestoreScreen: di"
ld hl,&4000"
ld de,&c000"
jr EsciSRScreen"
_SaveScreen: di"
ld hl, &c000"
ld de, &4000"
EsciSRScreen: ld bc,#4000"
ldir"
ret"
Certo manca ancora una gestione dell'area superiore ai 64KB nel caso dei modelli
6128, 6128Plus e con la presenza di espansione di memoria. Ma arriverà con il tempo.
E sopratutto mi "mangia" 16KB di memoria per salvare lo schermo, il che riduce lo
spazio dedicato al programma.
Il nome provvisorio è NOBasicCompiler e l'unico target, per il momento, è l'Amstrad CPC.
Mancava però una procedura per salvare e ripristinare lo schermo.
Alle volte la semplicità è la strada migliore in 10 righe ecco qui le due funzioni:
_RestoreScreen: di"
ld hl,&4000"
ld de,&c000"
jr EsciSRScreen"
_SaveScreen: di"
ld hl, &c000"
ld de, &4000"
EsciSRScreen: ld bc,#4000"
ldir"
ret"
Certo manca ancora una gestione dell'area superiore ai 64KB nel caso dei modelli
6128, 6128Plus e con la presenza di espansione di memoria. Ma arriverà con il tempo.
E sopratutto mi "mangia" 16KB di memoria per salvare lo schermo, il che riduce lo
spazio dedicato al programma.
Compilatore Z80 - II
20/09/2022 19:17
Oggi ho terminato di implementare alcuni comandi base del Basic nel NOBasic Compiler.
Funziona tutto, non credevo
Ora passo al progetto successivo e in futuro ottimizzerò il codice Z80
Funziona tutto, non credevo

Ora passo al progetto successivo e in futuro ottimizzerò il codice Z80

Compilatore Z80
20/08/2022 17:15
Sono passati quasi due mesi da quando ho cominciato a scrivere questo compilatore e visto che il lavoro mi occupa gran parte della giornata e mi dedico solo poche ore alla settimana sta venendo proprio bene.
I registri dello Z80 sono favolosi, Federico Faggin è proprio un genio.
Sono ancora nella fase della scrittura brutale l'ottimizzazione arriverà più avanti.
Partendo dalla sintassi del Basic che ho scritto per l'interprete trasformo il codice in istruzioni Z80 poi compilo con Pasmo e creo il file .DSK direttamente usando iDisk.
Funziona alla grande ed è velocissimo.

I registri dello Z80 sono favolosi, Federico Faggin è proprio un genio.
Sono ancora nella fase della scrittura brutale l'ottimizzazione arriverà più avanti.
Partendo dalla sintassi del Basic che ho scritto per l'interprete trasformo il codice in istruzioni Z80 poi compilo con Pasmo e creo il file .DSK direttamente usando iDisk.
Funziona alla grande ed è velocissimo.

LambdaSpeak FS
06/08/2021 10:51
Per i possessori, ovviamente felici
, di un Amstrad CPC la scheda Lambda Speak III è una grande espansione con molte caratteristiche.
Purtroppo molto costosa ma a questo proposito Stefan di Future Soft ha deciso di costruire una nuova scheda partendo appunto dal progetto di Michael Wessel
creando la LambdaSpeak FS. Ovviamente le differenze ci sono, nella nuova scheda manca il chip SPO256 sostituito dalla schedina Click2Spech e non è stata inserita la ROM.
Queste modifiche fanno si che con meno di 60€ si può avere questa splendida scheda che funziona alla grande.
Sto scrivendo questo messaggio ascoltando gli MP3 con il mio CPC 6128 Plus a cui è collegato la scheda LSFS.
Mi è arrivata proprio oggi e non sono riuscito a resistere da provarla subito.
Assieme alla scheda c'è un SD con i file disk sopracitati e un floppy da 3" con gli stessi file
I comandi RSX sono veramente molti e premettono da Basic di avere il pieno controllo della scheda.
Ottima la presenza del sensore termico e del orologio e con semplici comandi è possibile consultare i valori.
Con questa semplice riga in Basic si ottiene la temperatura dalla scheda:
10 t%=0 : |GETTEMP,@t%: print t%

Alcune delle caratteristiche salienti:
LambdaSpeak FS (2021)
- Sintesi vocale perfetta (inglese e spagnolo!) (Peccato manchi l'Italiano)
- Lettore MP3 con scheda SD
- Orologio in tempo reale (OS nativo, CP/M)
- Lettore di campioni PCM
- 81 nuovi comandi RSX
- Software anche per CP/M
- Emulazione di:
* sintetizzatore vocale SSA-1
* sintetizzatore vocale dk'tronics
* Amdrum Drumkit
* Modalità Epson e DECtalk
- Sensore termico
- Porta seriale (fino a 625000 Baud)
- Opzione MIDI IN e OUT
- Tre file DSK pieni di software
- Espansione RSX
- Sexy Lisa che parla
- Prodatrons Digitrakker
- Trasferimento XMODEM
- Connettore MX4
Qui il post di presentazione della scheda su CPCWiki

Purtroppo molto costosa ma a questo proposito Stefan di Future Soft ha deciso di costruire una nuova scheda partendo appunto dal progetto di Michael Wessel
creando la LambdaSpeak FS. Ovviamente le differenze ci sono, nella nuova scheda manca il chip SPO256 sostituito dalla schedina Click2Spech e non è stata inserita la ROM.
Queste modifiche fanno si che con meno di 60€ si può avere questa splendida scheda che funziona alla grande.
Sto scrivendo questo messaggio ascoltando gli MP3 con il mio CPC 6128 Plus a cui è collegato la scheda LSFS.
Mi è arrivata proprio oggi e non sono riuscito a resistere da provarla subito.
Assieme alla scheda c'è un SD con i file disk sopracitati e un floppy da 3" con gli stessi file

I comandi RSX sono veramente molti e premettono da Basic di avere il pieno controllo della scheda.
Ottima la presenza del sensore termico e del orologio e con semplici comandi è possibile consultare i valori.
Con questa semplice riga in Basic si ottiene la temperatura dalla scheda:
10 t%=0 : |GETTEMP,@t%: print t%

Alcune delle caratteristiche salienti:
LambdaSpeak FS (2021)
- Sintesi vocale perfetta (inglese e spagnolo!) (Peccato manchi l'Italiano)
- Lettore MP3 con scheda SD
- Orologio in tempo reale (OS nativo, CP/M)
- Lettore di campioni PCM
- 81 nuovi comandi RSX
- Software anche per CP/M
- Emulazione di:
* sintetizzatore vocale SSA-1
* sintetizzatore vocale dk'tronics
* Amdrum Drumkit
* Modalità Epson e DECtalk
- Sensore termico
- Porta seriale (fino a 625000 Baud)
- Opzione MIDI IN e OUT
- Tre file DSK pieni di software
- Espansione RSX
- Sexy Lisa che parla
- Prodatrons Digitrakker
- Trasferimento XMODEM
- Connettore MX4
Qui il post di presentazione della scheda su CPCWiki