Интроспективной называется программа, которая на вывод подает свой же исходный текст. Но я наткнулся на более интересный вариант: программа на Haskell, которая выводит программу на Python, которая выводит программу на Ruby, которая выводит исходную программу на Haskell.
К сожалению немного «течет» дизайн, но это необходимо:
Соответственно получаем такую цепочку: 1 -> 2 -> 3 -> 1, и программа в конечном счете выводит свой исходный текст :)
Разумеется этот кусок кода дошел до меня тоже по цепочке:
К сожалению немного «течет» дизайн, но это необходимо:
q a b c=putStrLn $ b ++ [toEnum 10,'q','('] ++ show b ++ [','] ++ show c ++ [','] ++ show a ++ [')'] main=q "q a b c=putStrLn $ b ++ [toEnum 10,'q','('] ++ show b ++ [','] ++ show c ++ [','] ++ show a ++ [')']" "def q(a,b,c):print b+chr(10)+'q('+repr(b)+','+repr(c)+','+repr(a)+')'" "def e(x) return 34.chr+x+34.chr end;def q(a,b,c) print b+10.chr+'main=q '+e(b)+' '+e(c)+' '+e(a)+' '+10.chr end"
Соответственно получаем такую цепочку: 1 -> 2 -> 3 -> 1, и программа в конечном счете выводит свой исходный текст :)
Разумеется этот кусок кода дошел до меня тоже по цепочке: