Perl 5 , rubi , JavaScript (cromado), PHP , Python 2 , Python 3 , 1206 bytes, marcar 6 6 /1206 = 38,6865671641791
q=1//2;s=+0;s|0;"/.__id__;#";_="""q=1//2;s=+0;s|0;"/.__id__;#";_={0}{1}{0};R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q={0}{2}{0};print(_.format(Q,_,q[0:-12]+R,"%"))""";R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q="""|;#<?ob_end_clean();
eval($_='"$t"?0?[$q=37 .chr+113 .chr+38 .chr,$p=(96 .chr+39 .chr)*4,$n=10 .chr,$s=39 .chr*12,$S=34 .chr*3]:eval("printf=console.log;c=String.fromCharCode;$q=c(96);$p=c(37,113,38,39).repeat(4);$n=c(10);$s=c(39).repeat(12);$S=c(34,34,34)"):[]?[$q=q(!g)^PA,$p=HARHARHARHAR^od2od2od2od2,$n=R^X,$s=bbbbbbbbbbbb^EEEEEEEEEEEE,$S=hhh^JJJ]:[$q=O^h,$p=str_repeat(RHa3^w9GS,4),$n=R^X,$s=str_repeat(b^E,12),$S=HHH^jjj];//#');printf($x='q=1//2;s=+0;s|0;"/.__id__;#";_=%7$sq=1//2;s=+0;s|0;"/.__id__;#";_={0}{1}{0};R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q={0}{2}{0};print(_.format(Q,_,q[0:-12]+R,"%8$s"))%7$s;R=chr((39,34)[1/2>0])*12;Q=chr((39,34)[1/2==0])*3;q=%7$s|;#<?ob_end_clean();%5$seval($_=%3$s%1$s%3$s);printf($x=%3$s%2$s%3$s,$_,$x,$q,$p,$n,$s,$S,"%8$s",![]||([]+[])?$n:"");//#%4$s%6$s%7$s;print(_.format(Q,_,q[0:-12]+R,"%8$s"))%9$s',$_,$x,$q,$p,$n,$s,$S,"%",![]||([]+[])?$n:"");//#`q&%`q&%`q&%`q&%''''''''''''""";print(_.format(Q,_,q[0:-12]+R,"%"))
Valide online Perl, Ruby, PHP, Python 2 e Python 3!
Nota : a execução do programa acima no console do Inspector no Chrome (que parece suportar argumentos posicionais para console.log
) retorna o programa correto.
Explicação
Isso ficou muito mais tempo do que eu esperava e também tornei minha vida um pouco mais difícil, então provavelmente continuarei mexendo nela. Também gostaria de adicionar mais idiomas, mas preciso encontrar algo que não se importe com um $
sigilo ...
Isso é muito bonito um formato Quine padrão onde o cálculo da cotação para uso é um pouco diferente para cada idioma: em Ruby %q&
é usado, usa PHP '
, JavaScript (Node.js) faz uso de `
e Perl 5 utiliza q(
... )
. Como apenas as aspas mudam, o restante do programa ainda é executável e sintaxe válida em cada idioma. O Python 2 e 3 são agrupados em torno do programa anterior usando o """
Python 2 e o '''
Python 3.
Os programas Perl e Ruby resultantes não são quines padrão, q
/ %q
s adicionais são adicionados a cada iteração, mas o primeiro programa retorna corretamente.
Os resultados são:
- Perl 5:
eval($_=q&
... q&);printf($x=q&
... q&,
... );//#'%`'%`'%`'%`''''''''''''"""
...
- Ruby:
eval($_=%q&
... %q&);printf($x=%q&
... %q&,
... );//#`'`'`'`'''''''''''''"""
...
- JavaScript (Chrome):
eval($_=`
... `);printf($x=`
... `,
... );//#%q&'%q&'%q&'%q&'''''''''''''"""
...
- PHP:
eval($_='
... ');printf($x='
... ',
... );//#`q&%`q&%`q&%`q&%''''''''''''"""
...
- Python 2:
... _="""
... """;
... q="""
...''''''''''''""";print(_.format(Q,_,q[0:-12]+R,"%"))
- Python 3:
... _='''
... ''';
... q='''
...""""""""""""''';print(_.format(Q,_,q[0:-12]+R,"%"))
Eu refiz muito isso, espero não ter perdido nada importante aqui. Ainda tenho um caminho a percorrer em qualquer lugar perto da partitura de Jo King ...