Mm, donuts

This commit is contained in:
Kevin Lange 2012-02-06 23:34:35 -06:00
parent d9b82bfb06
commit a95cc17853
2 changed files with 28 additions and 0 deletions

View File

@ -15,6 +15,7 @@ ENDRM = ../util/mk-end-rm
FREETYPE_INC = -I ../util/toaru-toolchain/i686-pc-toaru/include/freetype2/
FREETYPE_LIB = ../util/toaru-toolchain/i686-pc-toaru/lib/libfreetype.a
LIBM = ../util/toaru-toolchain/i686-pc-toaru/lib/libm.a
.PHONY: all clean
@ -51,6 +52,11 @@ clean:
@${CC} ${CFLAGS} -s -o $@ $< lib/list.o ${ERRORS}
@${END} "CC" "$< [w/libs]"
../hdd/bin/donut: donut.c
@${BEG} "CC" "$< [w/libs]"
@${CC} ${CFLAGS} -s -o $@ $< ${LIBM} ${ERRORS}
@${END} "CC" "$< [w/libs]"
../hdd/bin/%: %.cpp
@${BEG} "CPP" "$<"
@${CPP} ${CPPFLAGS} -s -o $@ $< ${ERRORS}

22
userspace/donut.c Normal file
View File

@ -0,0 +1,22 @@
/* http://a1k0n.net/2011/07/20/donut-math.html */
k;double sin()
,cos();main(){float A=
0,B=0,i,j,z[1760];char b[
1760];printf("\x1b[2J");for(;;
){memset(b,32,1760);memset(z,0,7040)
;for(j=0;6.28>j;j+=0.07)for(i=0;6.28
>i;i+=0.02){float c=sin(i),d=cos(j),e=
sin(A),f=sin(j),g=cos(A),h=d+2,D=1/(c*
h*e+f*g+5),l=cos (i),m=cos(B),n=s\
in(B),t=c*h*g-f* e;int x=40+30*D*
(l*h*m-t*n),y= 12+15*D*(l*h*n
+t*m),o=x+80*y, N=8*((f*e-c*d*g
)*m-c*d*e-f*g-l *d*n);if(22>y&&
y>0&&x>0&&80>x&&D>z[o]){z[o]=D;;;b[o]=
".,-~:;=!*#$@"[N>0?N:0];}}/*#****!!-*/
printf("\x1b[H");for(k=0;1761>k;k++)
putchar(k%80?b[k]:10);A+=0.04;B+=
0.02;}}/*****####*******!!=;:~
~::==!!!**********!!!==::-
.,~~;;;========;;;:~-.
..,--------,*/