CJam 0.6.6 dev / GolfScript, 15 14 12 bytes
"0$p"0$~a:n;
Graças a @ jimmy23013 por jogar fora 2 bytes!
Resto para ser atualizado.
Verificação
Como o envio envolve espaços em branco significativos, é melhor comparar os hexdumps.
$ xxd -g 1 mpquine
0000000: 22 60 30 24 7e 22 30 24 7e 4e 4d 3a 6e 3b "`0$~"0$~NM:n;
$
$ cjam mpquine | tee quine.gs | xxd -g 1
0000000: 22 60 30 24 7e 22 60 30 24 7e 0a "`0$~"`0$~.
$ golfscript quine.gs | xxd -g 1
0000000: 22 60 30 24 7e 22 60 30 24 7e 0a "`0$~"`0$~.
$ cjam quine.gs | xxd -g 1
0000000: 22 60 30 24 7e 22 60 30 24 7e "`0$~"`0$~
$
$ golfscript mpquine | tee quine.cjam | xxd -g 1
0000000: 22 60 30 24 7e 22 60 30 24 7e "`0$~"`0$~
$ cjam quine.cjam | xxd -g 1
0000000: 22 60 30 24 7e 22 60 30 24 7e "`0$~"`0$~
$ golfscript quine.cjam | xxd -g 1
0000000: 22 60 30 24 7e 22 60 30 24 7e 0a "`0$~"`0$~.
CJam
CJam imprime "`0$~"0$~
e um avanço de linha à direita.Experimente online!
O programa gerado é impresso "`0$~"0$~
com o avanço de linha à direita no GolfScript ( Experimente online! ), Mas sem o avanço de linha no CJam ( Experimente online! ).
Como a metaquina funciona
"`0$~" e# Push that string on the stack.
0$~ e# Push a copy and evaluate it:
e# ` Inspect the string, pushing "\"`0$~\"".
e# 0$ Push a copy.
e# ~ Evaluate, pushing "`0$~".
e# Both "\"`0$~\"" and "`0$~" are now on the stack.
NM e# Push "\n" and "".
:n; e# Map print over the elements of "" (none) and pop the result.
e# "\"`0$~\"", "`0$~", and "\n" are now on the stack, and the
e# characters they represent will be printed implicitly.
Como funciona o quine
"`0$~" # Push that string on the stack.
0$~ # As in CJam.
<LF> # Does nothing.
# "\"`0$~\"" and "`0$~" are now on the stack, and the characters
# they represent will be printed implicitly, plus a linefeed.
Ao contrário do GolfScript, o CJam não imprime um avanço de linha à direita, por padrão, portanto, não é um problema no CJam.
GolfScript
Impressões GolfScript "`0$~"0$~
, sem deixar espaço em branco.Experimente online!
O programa gerado é impresso "`0$~"0$~
sem espaços em branco no CJam ( Experimente online! ), Mas o GolfScript acrescenta um avanço de linha ( Experimente online! ).
Como a metaquina funciona
"`0$~"0$~ # As in CJam.
NM # Unrecognized token. Does nothing.
:n # Store the top of the stack – "`0$~" – in the variable n. n holds
# "\n" by default. When the program finishes, the interpreter
# prints n implicitly, usually resulting in a trailing linefeed.
# By redefining n, it will print "0$~" instead.
; # Pop the string from the stack so it won't be printed twice.
Como funciona o quine
"`0$~"0$~ e# Works as in GolfScript.
Ao contrário do CJam, o GolfScript anexa um avanço de linha ao conteúdo da pilha, portanto, isso não é uma questão no GolfScript.