summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xnocompile/bin/XuntilY.awk16
-rwxr-xr-xnocompile/libexec/gopherd.sh3
-rw-r--r--src/games/music.c59
-rw-r--r--src/libexec/sockip.c15
4 files changed, 92 insertions, 1 deletions
diff --git a/nocompile/bin/XuntilY.awk b/nocompile/bin/XuntilY.awk
new file mode 100755
index 0000000..6334d31
--- /dev/null
+++ b/nocompile/bin/XuntilY.awk
@@ -0,0 +1,16 @@
+#!/bin/sh
+if [ "_$3" = "_" ];then
+ count=1
+else
+ count="$3"
+fi
+awk '
+BEGIN {counter='$count'}
+/'$1'/, /'$2'/{
+ print $0;
+ if($0 ~ /'$2'/) {
+ counter--;
+ }
+ if(counter == 0) {nextfile}
+}
+'
diff --git a/nocompile/libexec/gopherd.sh b/nocompile/libexec/gopherd.sh
index 3b44296..d710f80 100755
--- a/nocompile/libexec/gopherd.sh
+++ b/nocompile/libexec/gopherd.sh
@@ -22,7 +22,8 @@ if grep -v "^${base}" <<< "${realpath}" > /dev/null;then
echo -e 'ierror!!! cant find base in realpath\tasdf\tasdf\tasdf\r'
exit 1
fi
-myIP=$(hop0 $(/usr/local/libexec/peerip | head -n1) | cut -d% -f1)
+#myIP=$(hop0 $(/usr/local/libexec/peerip | head -n1) | cut -d% -f1)
+myIP=$(/usr/local/libexec/sockip | head -n1 | cut -d% -f1)
hostname=$(rdns ${myIP})
if [ ! "${hostname}" ]; then
hostname=${myIP}
diff --git a/src/games/music.c b/src/games/music.c
new file mode 100644
index 0000000..3b52b4e
--- /dev/null
+++ b/src/games/music.c
@@ -0,0 +1,59 @@
+#include <stdio.h>
+#include <string.h>
+#include <time.h>
+#include <stdlib.h>
+
+char cheat;
+
+void print_note(char n) {
+ printf(" %c \n",n=='G'?cheat?n:'o':' ');
+ printf("--%c--\n",n=='F'?cheat?n:'o':'-');
+ printf(" %c \n",n=='E'?cheat?n:'o':' ');
+ printf("--%c--\n",n=='D'?cheat?n:'o':'-');
+ printf(" %c \n",n=='C'?cheat?n:'o':' ');
+ printf("--%c--\n",n=='B'?cheat?n:'o':'-');
+ printf(" %c \n",n=='A'?cheat?n:'o':' ');
+ printf("--%c--\n",n=='g'?cheat?n:'o':'-');
+ printf(" %c \n",n=='f'?cheat?n:'o':' ');
+ printf("--%c--\n",n=='e'?cheat?n:'o':'-');
+ printf(" %c \n",n=='d'?cheat?n:'o':' ');
+ printf(" %c \n",n=='c'?cheat?n:'o':' ');
+ printf(" %c \n",n=='b'?cheat?n:'o':' ');
+ printf(" %c \n",n=='a'?cheat?n:'o':' ');
+}
+
+char notes[]="ABCDEFGabcdefg";
+
+int main(int argc,char *argv[]) {
+ int count;
+ int correct=0;
+ int total=20;
+ char note;
+ cheat=argc > 1;
+ short in;
+ srandom(time(0));
+ total=20;
+ count=total;
+ printf("\x1b[H\x1b[J");
+ time_t end;
+ time_t start=time(0);
+ for(;in != -1 && count;count--) {
+ note=notes[random()%strlen(notes)];
+ print_note(note);
+ in=fgetc(stdin);
+ if(in == note || in == note+' ') {
+ printf("\x1b[H\x1b[J");
+ printf("Yay!\n");
+ correct++;
+ in=fgetc(stdin);//kill the newline
+ } else {
+ printf("\x1b[H\x1b[J");
+ printf("boo!\n");
+ in=fgetc(stdin);//kill the newline
+ }
+ }
+ end=time(0);
+ printf("took you %lld seconds\n",end-start);
+ printf("got %d/%d right.\n",correct,total);
+ return 0;
+}
diff --git a/src/libexec/sockip.c b/src/libexec/sockip.c
new file mode 100644
index 0000000..542a88d
--- /dev/null
+++ b/src/libexec/sockip.c
@@ -0,0 +1,15 @@
+#include <stdio.h>
+#include <sys/socket.h>
+#include <netdb.h>
+#include <netinet/in.h>
+
+int main(int argc,char *argv[]) {
+ struct sockaddr_in6 sa6;
+ unsigned int sl=sizeof(sa6);
+ char h[NI_MAXHOST], s[NI_MAXSERV];
+ if(getsockname(0,(struct sockaddr *)&sa6,&sl) == -1) return 1;
+ if(getnameinfo((struct sockaddr *)&sa6,sl,h,sizeof(h),s,sizeof(s),NI_NUMERICHOST|NI_NUMERICSERV)) return 2;
+ puts(h);
+ puts(s);
+ return 0;
+}