MarioLANG è un linguaggio di programmazione bidimensionale in cui il codice sorgente assomiglia a un livello di Super Mario Bros. Inoltre, il suo set di istruzioni è molto simile a quello di Brainfuck . Ciò significa che MarioLANG è essenzialmente un Brainfuck 2-D in cui il puntatore dell'istruzione si muove come Mario. Quindi, quando ho scritto la mia presentazione MarioLANG per il Quiz sul linguaggio di programmazione, ho iniziato convertendo un Brainfuck "Hello, World!" programma per MarioLANG. Ho notato che questo è possibile con un processo molto sistematico, quindi scriviamo un compilatore Brainfuck-to-MarioLANG!
Nota: le specifiche di MarioLANG non sono del tutto inequivocabili, quindi presumo l'interpretazione dell'implementazione di Ruby .
Spiegherò il processo con il seguente programma Brainfuck:
++[>+++++[>+++++++>++++++++++>+++>+<<<<-]<-]>>++.>+.+++++++..+++.>+++.>.
Stampa Hello!
e una nuova riga finale.
Converti
<
e>
in(
e)
, rispettivamente:++[)+++++[)+++++++)++++++++++)+++)+((((-](-]))++.)+.+++++++..+++.)+++.).
Aggiungi un piano su cui camminare Mario:
++[)+++++[)+++++++)++++++++++)+++)+((((-](-]))++.)+.+++++++..+++.)+++.). ========================================================================
Ora il problema è che MarioLANG non ha loop come
[
e]
. Invece, dobbiamo usare gli ascensori e le istruzioni direzionali per fare in modo che Mario cammini in un ciclo. In primo luogo, sostituiamo[
con>
e cambiare la parola a"
. E abbiamo anche sostituiamo]
con[!
e cambiare la parola a=#
:++>)+++++>)+++++++)++++++++++)+++)+((((-[!(-[!))++.)+.+++++++..+++.)+++.). =="======"===============================#===#============================
Gli
"
e#
possono formare ascensori (a partire da#
, finendo a"
), quindi ora tutto ciò di cui abbiamo bisogno sono piani ausiliari per far tornare Mario. L'inizio con!
e termina con<
:++>)+++++>)+++++++)++++++++++)+++)+((((-[!(-[!))++.)+.+++++++..+++.)+++.). =="======"===============================#===#============================ ! < #===============================" ! < #=========================================="
Si noti che tutte le linee devono essere lunghe almeno quanto il più grande anello di chiusura, poiché l'interprete non è in grado di collegare le estremità dell'ascensore su linee più brevi. Pertanto, riempiamo le linee di mezzo con spazi.
E questo è tutto. Abbiamo un programma MarioLANG perfettamente funzionante ed equivalente.
La sfida
Dato un programma Brainfuck valido, implementare la procedura sopra descritta per compilarlo in un programma MarioLANG.
Si può presumere che ci siano solo caratteri di comando nell'input, cioè nessun carattere tranne ,.+-<>[]
.
Tutto il piano ausiliario deve essere il più vicino possibile al piano principale del programma. Puoi scegliere di riempire le linee dei piani intermedi il meno possibile (fino alla larghezza del più grande anello di chiusura) o alla fine del programma principale.
È possibile scrivere un programma o una funzione, prendendo l'input tramite STDIN (o l'alternativa più vicina), l'argomento della riga di comando o l'argomento della funzione e producendo il risultato tramite STDOUT (o l'alternativa più vicina), il valore di ritorno della funzione o il parametro della funzione (out). Se non si stampa il risultato su STDOUT, dovrebbe essere comunque una singola stringa separata da nuova riga.
Questo è il golf del codice, quindi vince la risposta più breve (in byte).
Casi test
I casi di test sono formattati come segue: la prima riga è il programma Brainfuck (input), quindi c'è una riga vuota e tutto fino a quando la riga vuota successiva è l'output previsto in MarioLANG. Questi esempi utilizzano la quantità minima di spazi imbottiti. In alternativa, è possibile riempire ogni riga con spazi alla larghezza della prima riga dell'output.
>,++-.<
),++-.(
=======
,[.,]
,>.,[!
="===#
! <
#==="
>>[-]<<[->>+<<]
))>-[!((>-))+(([!
=="==#=="=======#
! < ! <
#==" #======="
++[>+++++[>+++++++>++++++++++>+++>+<<<<-]<-]>>++.>+.+++++++..+++.>+++.>.
++>)+++++>)+++++++)++++++++++)+++)+((((-[!(-[!))++.)+.+++++++..+++.)+++.).
=="======"===============================#===#============================
! <
#==============================="
! <
#=========================================="
[][[[][[]]][]][[]]
>[!>>>[!>>[![![!>[![!>>[![!
"=#"""=#""=#=#=#"=#=#""=#=#
! < ! < ! < ! < ! <
#=" #=" #=" #=" #="
! < ! <
#====" #===="
! <
#=========="
! <
#================"
>>+++++++>>++>>++++>>+++++++>>+>>++++>>+>>+++>>+>>+++++>>+>>++>>+>>++++++>>++>>++++>>+++++++>>+>>+++++>>++>>+>>+>>++++>>+++++++>>+>>+++++>>+>>+>>+>>++++>>+++++++>>+>>+++++>>++++++++++++++>>+>>+>>++++>>+++++++>>+>>+++++>>++>>+>>+>>++++>>+++++++>>+>>+++++>>+++++++++++++++++++++++++++++>>+>>+>>++++>>+++++++>>+>>+++++>>++>>+>>+>>+++++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>+>>++>>+>>++++++>>++>>++++>>+++++++>>+>>+++++>>+++++++>>+>>+++++>>+>>+>>+>>++++>>+>>++>>+>>++++++>>+>>+++++>>+++++++>>+>>++++>>+>>+>>++>>+++++>>+>>+++>>+>>++++>>+>>++>>+>>++++++>>+>>+++++>>+++++++++++++++++++>>++>>++>>+++>>++>>+>>++>>++++>>+++++++>>++>>+++++>>++++++++++>>+>>++>>++++>>+>>++>>+>>++++++>>++++++>>+>>+>>+++++>>+>>++++++>>++>>+++++>>+++++++>>++>>++++>>+>>++++++[<<]>>[>++++++[-<<++++++++++>>]<<++..------------------->[-<.>>+<]>[-<+>]>]<<[-[-[-[-[-[-[>++>]<+++++++++++++++++++++++++++++>]<++>]<++++++++++++++>]<+>]<++>]<<[->.<]<<]
))+++++++))++))++++))+++++++))+))++++))+))+++))+))+++++))+))++))+))++++++))++))++++))+++++++))+))+++++))++))+))+))++++))+++++++))+))+++++))+))+))+))++++))+++++++))+))+++++))++++++++++++++))+))+))++++))+++++++))+))+++++))++))+))+))++++))+++++++))+))+++++))+++++++++++++++++++++++++++++))+))+))++++))+++++++))+))+++++))++))+))+))+++++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))+))++))+))++++++))++))++++))+++++++))+))+++++))+++++++))+))+++++))+))+))+))++++))+))++))+))++++++))+))+++++))+++++++))+))++++))+))+))++))+++++))+))+++))+))++++))+))++))+))++++++))+))+++++))+++++++++++++++++++))++))++))+++))++))+))++))++++))+++++++))++))+++++))++++++++++))+))++))++++))+))++))+))++++++))++++++))+))+))+++++))+))++++++))++))+++++))+++++++))++))++++))+))++++++>(([!))>)++++++>-((++++++++++))[!((++..-------------------)>-(.))+([!)>-(+)[!)[!((>->->->->->->)++)[!(+++++++++++++++++++++++++++++)[!(++)[!(++++++++++++++)[!(+)[!(++)[!((>-).([!(([!
========================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================================="===#=="======="================#=========================="========#="=====#==#=="="="="="="="=====#================================#=====#=================#====#=====#=="=====#===#
! < ! < ! < ! < ! < ! <
#===" #================" #========" #=====" #=====" #====="
! < ! <
#=======================================================================" #========================================"
! <
#================================================"
! <
#===================================================================="
! <
#==========================================================================="
! <
#==================================================================================="
! <
#=================================================================================================="