Jouez au golf à Double Quine pour plus de bien!

18

Bonsoir mesdames et messieurs.

Ce soir - nous avons un défi de code. Une compétition qui sera définie non pas en nombre de points (à la Asteroids) mais simplement si vous pouvez la terminer (à la Zelda). Et pour la comparaison, la quantité d'octets (euh ... mais vous avez dit ...).

Votre défi est de composer une seule quine qui se compile à la fois dans WhiteSpace et dans toute autre langue de votre choix. Les deux quines doivent avoir une sortie absolument identique (qui en tant que quine est absolument identique au code source). Votre quine doit être de plus de 3 octets.

Votre score est la taille de votre code source en octets.

Étant donné que ce défi implique WhiteSpace, veuillez échapper vos réponses afin qu'elles soient claires - de préférence dans le style C. Votre score est la source d'origine en octets - pas la version échappée.

Bonne chance.

lochok
la source
1
Un vidage hexadécimal xxd ferait-il l'affaire?
Ilmari Karonen
Oui. Je l'accepte.
lochok

Réponses:

19

Espaces et Perl, 992 975 caractères

Bonsoir mesdames et messieurs.

Pour commencer, voici ma soumission encodée en base64, qui me semble être la meilleure façon de communiquer un grand programme Whitespace. (Vous ne voulez vraiment pas utiliser un encodage qui laisse les blancs tels quels, il est donc inutile de sélectionner quelque chose de plus "lisible".)

c2F5PDwgeDI7c2F5PDwwLDAgIApzYXk8PCB4MjtzYXk8PDAsMCAgCgoJCQogICAJCSAgCSAgCSAJ
CSAgCSAgCQkgCSAJIAkJCQkJICAJCSAJCQkgCQkJCQkgCSAJIAkJIAkgCSAgIAkJCQkJICAgCQkg
IAkgCQkgCSAJCSAJICAgIAkJCQkgCSAgCSAJCSAJICAgIAkgCQkgICAJICAgICAgCQkJIAkJCQkJ
IAkJCSAJCQkJICAgICAJCQkgCSAgICAgIAkJCQkJICAgICAgCQkgICAJCSAgICAJCQkJCQkJCSAg
CSAJIAkgICAJCQkgICAJCQkJCSAgCQkJCSAJICAgIAkgCQkJCQkgCSAgICAgCSAgCSAJICAgICAg
CSAgICAJICAgICAJCSAgIAkJCSAJIAkJCQkJCSAJCSAJIAkgICAgICAgCQkgIAkgICAgICAgICAg
IAkJICAgCSAJCQkgCSAgICAgCQkJCQkJIAkgICAgCQkJCSAJCQkJICAJCQkgICAJCQkgCSAgCSAg
IAkJCQkgIAkJIAkJCSAgIAkJCSAJCQkgCQkJICAJCSAJICAJIAkJCSAJIAkgCQkgICAgIAkgCSAJ
ICAJICAJIAkJICAgICAJIAkgICAgCQkJCSAgCSAJCSAJIAkJIAkgIAkgCSAJCSAJCSAJCSAJCQkg
CQkJICAgIAkJCSAgCSAgCQogICAJICAgICAJCQkJCSAJCSAJIAkgCSAJICAJCQkgICAJICAgCSAg
ICAJCSAJICAgICAgICAgCSAgIAkJCQkgCQkgICAgCQkgCSAJICAJCQkgCQkJCSAJCQkgICAJICAg
IAkgCSAJCQkgIAkJCQkgCSAJCSAJIAkgCQkJCSAJICAJIAkJIAkgICAJCiAKICAKICAgIAogCSAg
CQoKICAJCiAKICAgIAkJCQkgCSAKCSAJCQkKICAgICAJCQkJIAkgCgkgCSAgCiAgIAkJCgkgIAoK
CQkJCiAKCgoJIAkKICAgCSAgIAkgIAoKIAkKIAkgIAkKCiAJIAogICAJIAoKIAkKCiAJIAoKIAkK
CQogCSAgIAkgCgogCQoKCgoKICAgCiAgIAogCiAKIAkKCiAJCgogICAgCiAKIAoJIAogCiAgICAJ
IAoJIAkJIAoJICAgCSAKCSAJIAogCSAgCgogIAogCiAgICAJCQoJIAkJICAJCSAJCQkKCSAgCiAg
CQkJICAgCgkgCQkgICAJICAgICAKCSAgIAkKICAgICAJCQoJIAkgIAogICAJCQoJICAKCgkJCiAK
CgoJCjAK

Voici un extrait qui met en évidence toutes les parties visibles de la source. est utilisé pour indiquer un onglet et pour indiquer une nouvelle ligne.

say<< x2;say<<0,0  ↲
say<< x2;say<<0,0  ↲
↲
⇥⇥↲
   ⇥⇥  ⇥ [... etcetera ... skipping rest of a really long line ...]↲
   ⇥⇥⇥ ⇥⇥[... etcetera ... shorter but still quite a long line ...]↲
 ↲
  ↲
    ↲
 ⇥  ⇥↲
[... etcetera ... whole lotta whitespace in here ...]
⇥⇥↲
 ↲
↲
↲
⇥↲
0↲

Perl était le choix naturel pour la deuxième langue dans ce défi, étant l'un des meilleurs langages à usage général pour écrire des quines compactes. Mon quine Perl le plus court est de 19 octets:

say<< x2
say<< x2
 

- et vous pouvez voir comment c'était la graine pour la moitié Perl de la double quine. En comparaison, ma meilleure quine d'espace blanc est longue de 541 octets. (Bien que les plus courts existent - 445 octets est le meilleur que j'ai vu.)

Du point de vue de l'interpréteur Perl, la première ligne du fichier source du double quine contient les deux instructions qui composent l'ensemble du programme proprement dit, car le contenu restant est deux chaînes entre guillemets. La première chaîne est la ligne répétée de Perl et est délimitée par la troisième ligne vierge. La deuxième chaîne est entièrement en blanc et s'étend de la quatrième ligne de la source jusqu'au 0délimiteur au bas du fichier.

Lorsqu'elles sont considérées comme un programme d'espaces blancs, les quatre premières lignes contiennent trois instructions qui sont largement inutiles. (Leur effet est de pousser deux valeurs nulles sur la pile, puis de rejeter la seconde.) Elles sont incluses juste pour franchir en toute sécurité les nouvelles lignes requises par le programme Perl - le vrai programme démarre ensuite. Plutôt que de citer la source illisible plus loin, voici une paraphrase des instructions qui composent le programme Whitespace, dans un format de type assembleur:

# Representation of "say<< ;say<<0,0  \n" in base 122 as ASCII chars.
PERLCODE = 44892457841068708924520433691075560592081

# Represention of the whitespace program, following the "push PERLCODE"
# instruction, in base 3 (see comments on wsout).
WSCODE = 9823454421986355730445143846606456399449033186160554878002671428613111806443504867738858766142050504887335990409088441824104338753030405625930185

# Set up the stack and the heap. The first three instructions are not
# particularly useful; they're just there to skip past the newlines in
# the Perl code. (Though the initial zero on the stack does get used
# at the very end.)

        push    0
        push    0
        jneg    wsout

        push    WSCODE
        push    PERLCODE
        dup
        dup
        push    0
        copy    1

# Output the first four lines of the file.

perl:   dup
        mod     122
        putchar
        div     122
        dup
        jnzero  perl
        pop
        jzero   perl
        push    68              # represents "jneg wsout"
        call    wsout

# Output the rest of the file.

        copy    1
        call    pushout
        push    2
        call    wsout
        call    pushout
        call    wsout
        putnum
        push    2
        call    wsout
        exit

# pushout: Output a Whitespace push instruction, using the number on
# the top of the stack as the instruction's argument. (Recursion is
# used to output the bits MSB-first.)

pushout:
        push    0
        dup
        call    wsout
        call    wsout
bits:   dup
        jzero   bitend
        dup
        mod     2
        swap
        div     2
        call    bits
bitend: call    wsout
        ret

# wsout: Output a sequence of whitespace characters as represented by
# the number on the top of the stack. The number is read in base 3,
# LSB-first, with 0 = SPC, 1 = TAB, 2 = NL. Calling wsout with a value
# of zero will output a single space.

wsout:
        dup
        mod     3
        mul     -23             # some ugly math that transforms
        mod     -24             # (0, 1, 2) into (32, 9, 10)
        add     32
        putchar
        div     3
        dup
        jnzero  wsout
        pop
        ret

Les nombres géants en haut sont ce que nous, les utilisateurs d'espace blanc, devons utiliser à la place des chaînes réelles. Ne vous embêtez pas à essayer d'exécuter ceci sur un interpréteur Whitespace qui n'a pas de support bignum approprié.

Enfin, voici à nouveau le programme, mais cette fois avec des échappements de style C, car il a été spécifiquement demandé:

say<< x2;say<<0,0  \nsay<< x2;say<<0,0  \n\n\t\t\n   \t\t  \t  \t \t\t  \t  \t\t \t \t \t\t\t\t\t  \t\t \t\t\t \t\t\t\t\t \t \t \t\t \t \t   \t\t\t\t\t   \t\t  \t \t\t \t \t\t \t    \t\t\t\t \t  \t \t\t \t    \t \t\t   \t      \t\t\t \t\t\t\t\t \t\t\t \t\t\t\t     \t\t\t \t      \t\t\t\t\t      \t\t   \t\t    \t\t\t\t\t\t\t\t  \t \t \t   \t\t\t   \t\t\t\t\t  \t\t\t\t \t    \t \t\t\t\t\t \t     \t  \t \t      \t    \t     \t\t   \t\t\t \t \t\t\t\t\t\t \t\t \t \t       \t\t  \t           \t\t   \t \t\t\t \t     \t\t\t\t\t\t \t    \t\t\t\t \t\t\t\t  \t\t\t   \t\t\t \t  \t   \t\t\t\t  \t\t \t\t\t   \t\t\t \t\t\t \t\t\t  \t\t \t  \t \t\t\t \t \t \t\t     \t \t \t  \t  \t \t\t     \t \t    \t\t\t\t  \t \t\t \t \t\t \t  \t \t \t\t \t\t \t\t \t\t\t \t\t\t    \t\t\t  \t  \t\n   \t     \t\t\t\t\t \t\t \t \t \t \t  \t\t\t   \t   \t    \t\t \t         \t   \t\t\t\t \t\t    \t\t \t \t  \t\t\t \t\t\t\t \t\t\t   \t    \t \t \t\t\t  \t\t\t\t \t \t\t \t \t \t\t\t\t \t  \t \t\t \t   \t\n \n  \n    \n \t  \t\n\n  \t\n \n    \t\t\t\t \t \n\t \t\t\t\n     \t\t\t\t \t \n\t \t  \n   \t\t\n\t  \n\n\t\t\t\n \n\n\n\t \t\n   \t   \t  \n\n \t\n \t  \t\n\n \t \n   \t \n\n \t\n\n \t \n\n \t\n\t\n \t   \t \n\n \t\n\n\n\n\n   \n   \n \n \n \t\n\n \t\n\n    \n \n \n\t \n \n    \t \n\t \t\t \n\t   \t \n\t \t \n \t  \n\n  \n \n    \t\t\n\t \t\t  \t\t \t\t\t\n\t  \n  \t\t\t   \n\t \t\t   \t     \n\t   \t\n     \t\t\n\t \t  \n   \t\t\n\t  \n\n\t\t\n \n\n\n\t\n0\n
boite à pain
la source
2
Hou la la! Je pensais que le brainfuck serait la première solution.
boothby
1
J'y ai pensé, mais le problème est que les quines Brainfuck sont encore plus longues que les quines Whitespace. Entre les deux, le résultat aurait été énorme.
boîte à pain