Merge pull request #77 from jhbadger/master

Initial version of kona package
This commit is contained in:
Fredrik Fornwall 2015-12-06 20:35:55 +01:00
commit 5b61474814
8 changed files with 186 additions and 0 deletions

20
packages/kona/0.c.patch Normal file
View File

@ -0,0 +1,20 @@
--- ../kona-Win.3.36-64/src/0.c 2015-07-30 11:18:02.000000000 -0400
+++ ./src/0.c 2015-12-06 03:24:04.000000000 -0500
@@ -84,7 +84,7 @@
GC; }
else if( (3==ABS(t) && (!strcmp(m,"/dev/fd/0") || !strcmp(m,"/dev/stdin"))) //read stdin
|| 4==t && (!strcmp(*kS(a),"/dev/fd/0") || !strcmp(*kS(a),"/dev/stdin")) ){
- b=getdelim_(&v,(size_t * __restrict__)&s,EOF,stdin);
+ b=new_getdelim_(&v,(size_t * __restrict__)&s,EOF,stdin);
P(freopen_stdin() == NULL, FE)
if(b==-1){z=newK(0,0); GC;} }
else { //read mapped file
@@ -868,7 +868,7 @@
FILE *f; K z,l; S s=0; I n=0;
f=popen(cmd,"r"); P(!f,_n())
z=newK(0,0); //oom
- while (getline_(&s, (size_t * __restrict__)&n, f) >= 0) {
+ while (new_getline_(&s, (size_t * __restrict__)&n, f) >= 0) {
l=newK(-3,n-1); strncpy(kC(l),s,n-1); kap(&z,&l); }
free(s); pclose(f);
R z; }

View File

@ -0,0 +1,34 @@
--- ../kona-Win.3.36-64/Makefile 2015-07-30 11:18:02.000000000 -0400
+++ ./Makefile 2015-12-06 04:14:40.000000000 -0500
@@ -1,10 +1,10 @@
-PREFIX = /usr/local
-CFLAGS=-g
+PREFIX = @TERMUX_PREFIX@
+CFLAGS=-O3
PRODFLAGS = -O3 #-pg -g3
LIB=libkona.a
DEVFLAGS = -O0 -g3 -DDEBUG -Wunused -Wreturn-type -Wimplicit-int #-Wall
-OS := $(shell uname -s | tr "[:upper:]" "[:lower:]")
+OS = android
# Win-64
ifeq (mingw32_nt-6.2,$(OS))
@@ -34,7 +34,7 @@
src/ks.o src/v.o src/va.o src/vc.o src/vd.o src/vf.o src/vg.o src/vq.o
LDFLAGS = -Wl,--gc-sections -Wl,-z,nocopyreloc -lgcc -no-canonical-prefixes \
-Wl,--no-undefined -Wl,-z,noexecstack -Wl,-z,relro -Wl,-z,now -mthumb \
- -lc -lm -ldl
+ -fPIE -pie -lc -lm -ldl
CFLAGS += -fPIE -fpic -ffunction-sections -funwind-tables -fstack-protector \
-no-canonical-prefixes -mtune=xscale -msoft-float -mthumb \
-fomit-frame-pointer -fno-strict-aliasing
@@ -109,7 +109,7 @@
test: k_test
install:
- install k $(PREFIX)/bin/k
+ install k ${PREFIX}/bin/k
clean:
$(RM) -r k k_test *.exe k.dSYM k_test.dSYM src/*.o src/win/*.o

12
packages/kona/build.sh Normal file
View File

@ -0,0 +1,12 @@
TERMUX_PKG_VERSION=3.36
TERMUX_PKG_FOLDERNAME=kona-Win.$TERMUX_PKG_VERSION-64
TERMUX_PKG_HOMEPAGE=https://github.com/kevinlawler/kona
TERMUX_PKG_DESCRIPTION="Open-source implementation of the APL-like K programming language"
TERMUX_PKG_SRCURL="https://github.com/kevinlawler/kona/archive/Win.$TERMUX_PKG_VERSION-64.zip"
TERMUX_PKG_DEPENDS=""
TERMUX_PKG_BUILD_IN_SRC=yes
TERMUX_PKG_MAINTAINER="Jonathan Badger <jhbadger@gmail.com>"
termux_step_make_install () {
make install
}

11
packages/kona/c.c.patch Normal file
View File

@ -0,0 +1,11 @@
--- ../kona-Win.3.36-64/src/c.c 2015-07-30 11:18:02.000000000 -0400
+++ ./src/c.c 2015-12-06 03:19:35.000000000 -0500
@@ -463,7 +463,7 @@
w=t; while(isspace(*w++))l++;
if(l==n||!n){if(y)cd(y); y=0; continue;}
O("%s ",t);
- if(-1==getline_(&u,&m,stdin))GC;
+ if(-1==new_getline_(&u,&m,stdin))GC;
d=stepopt(u,m);
if(d==1){if(y)cd(y); y=0; continue;}else if(d==2)GC;
show(k=ex(wd(t,n)));

View File

@ -0,0 +1,40 @@
--- ../kona-Win.3.36-64/src/getline.c 2015-07-30 11:18:02.000000000 -0400
+++ ./src/getline.c 2015-12-06 03:21:45.000000000 -0500
@@ -29,12 +29,12 @@
R 0;
}
-I getline_(S *s,size_t * __restrict__ n,FILE *f){R getdelim_(s,n,'\n',f);}
+I new_getline_(S *s,size_t * __restrict__ n,FILE *f){R new_getdelim_(s,n,'\n',f);}
-I getdelim_(S *s,size_t * __restrict__ n,I d,FILE *f)
+I new_getdelim_(S *s,size_t * __restrict__ n,I d,FILE *f)
{
I m; S z;
- if(getdelim(s,n,d,f)==-1){*n=0; R -1;}
+ if(new_getdelim(s,n,d,f)==-1){*n=0; R -1;}
m=strlenn(*s,*n);
z=strdupn(*s,m);
free(*s);
@@ -44,8 +44,8 @@
#if defined(__OpenBSD__) || defined(__NetBSD__) || \
(defined(__MACH__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1070)
-I getline(S *s,I*n, FILE *f){ R getdelim(s,n,'\n',f);}
-I getdelim(S *s,I*n, I d, FILE *f)//target, current capacity, delimiter, file
+I getline(S *s,I*n, FILE *f){ R new_getdelim(s,n,'\n',f);}
+I new_getdelim(S *s,I*n, I d, FILE *f)//target, current capacity, delimiter, file
{
unsigned char *q;
I w=0;
@@ -92,8 +92,8 @@
#endif
#ifdef WIN32
-I getline(S *s,I*n, FILE *f){ R getdelim(s,n,'\n',f);}
-I getdelim(S *s,I*n, I d, FILE *f) { //target, current capacity, delimiter, file
+I getline(S *s,I*n, FILE *f){ R new_getdelim(s,n,'\n',f);}
+I new_getdelim(S *s,I*n, I d, FILE *f) { //target, current capacity, delimiter, file
char *q; I w=0;
if (!s) {errno = EINVAL; goto error;}
if (f->_cnt <= 0) {

View File

@ -0,0 +1,23 @@
--- ../kona-Win.3.36-64/src/getline.h 2015-07-30 11:18:02.000000000 -0400
+++ ./src/getline.h 2015-12-06 03:21:00.000000000 -0500
@@ -1,16 +1,16 @@
K _p();
S strdupn(S s,I k);
I strlenn(S s,I k);
-I getdelim_(S *s,size_t * __restrict__ n,I d,FILE *f);
-I getline_(S *s,size_t * __restrict__ n,FILE *f);
+I new_getdelim_(S *s,size_t * __restrict__ n,I d,FILE *f);
+I new_getline_(S *s,size_t * __restrict__ n,FILE *f);
I appender(S *s,I *n,S t,I k);
I expander(S *s,I n);
#if defined(__OpenBSD__) || defined(__NetBSD__) || \
(defined(__MACH__) && __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1070) || \
defined(__ANDROID__)
-I getline(S *s,size_t * __restrict__ n,FILE *f);
-I getdelim(S *s,size_t * __restrict__ n,I d,FILE *f);
+I new_getline(S *s,size_t * __restrict__ n,FILE *f);
+I new_getdelim(S *s,size_t * __restrict__ n,I d,FILE *f);
#endif
#if WIN32

View File

@ -0,0 +1,20 @@
--- ../kona-Win.3.36-64/src/getline_android.c 2015-07-30 11:18:02.000000000 -0400
+++ ./src/getline_android.c 2015-12-06 03:22:55.000000000 -0500
@@ -9,7 +9,7 @@
#include <errno.h>
#include <stdlib.h>
-I getline(S *s,size_t*n, FILE *f){ R getdelim(s,n,'\n',f);}
+I new_getline(S *s,size_t*n, FILE *f){ R getdelim(s,n,'\n',f);}
/* getdelim.c --- Implementation of replacement getdelim function.
Copyright (C) 1994, 1996-1998, 2001, 2003, 2005-2012 Free Software
@@ -44,7 +44,7 @@
necessary. Returns the number of characters read (not including
the null terminator), or -1 on error or EOF. */
-I getdelim (S *lineptr, size_t * __restrict__ n, I delimiter, FILE *fp)
+I new_getdelim (S *lineptr, size_t * __restrict__ n, I delimiter, FILE *fp)
{
ssize_t result;
size_t cur_len = 0;

26
packages/kona/kc.c.patch Normal file
View File

@ -0,0 +1,26 @@
--- ../kona-Win.3.36-64/src/kc.c 2015-07-30 11:18:02.000000000 -0400
+++ ./src/kc.c 2015-12-06 03:18:50.000000000 -0500
@@ -34,12 +34,12 @@
I wds_(K*a,FILE*f,I l) {
S s=0,t=0; I b=0,c=0,m=0,n=0,v=0; K z=0; PDA p=0;
I o=isatty(STDIN)&&f==stdin;
- if(-1==(c=getline_(&s,(size_t * __restrict__)&n,f)))GC;
+ if(-1==(c=new_getline_(&s,(size_t * __restrict__)&n,f)))GC;
appender(&t,&m,s,n);
while(1==(v=complete(t,m,&p,0))) {
b=parsedepth(p);
if(o)prompt(b+l);
- if(-1==(c=getline_(&s,(size_t * __restrict__)&n,f)))GC;
+ if(-1==(c=new_getline_(&s,(size_t * __restrict__)&n,f)))GC;
appender(&t,&m,s,n); }
SW(v){CS(2,show(kerr("unmatched"));GC) CS(3,show(kerr("nest")); GC)}
z=newK(-3,m-1);
@@ -200,7 +200,7 @@
//I o = isatty(STDIN) && f==stdin; //display results to stdout?
I o = isatty(STDIN); //display results to stdout?
- if(-1==(c=getline(&s,(size_t * __restrict__)&m,f))) GC;
+ if(-1==(c=new_getline(&s,(size_t * __restrict__)&m,f))) GC;
if(s[0]=='\\' && s[1]=='\n') {
if(fCheck) { fCheck=0; R 0; } //escape suspended execution with single backslash
if(*a) GC; } //escape continue with single backslash