Skip to content

Commit

Permalink
for solving problem with colon operator in arrays: github issue #12
Browse files Browse the repository at this point in the history
  • Loading branch information
kollokollo committed Jan 18, 2021
1 parent d794be8 commit a4d84f3
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 32 deletions.
35 changes: 15 additions & 20 deletions src/array.c
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/* array.c (c) Markus Hoffmann */

/* This file is part of X11BASIC, the basic interpreter for Unix/X
* ============================================================
* ====================================================================
* X11BASIC is free software and comes with NO WARRANTY - read the file
* COPYING for details
*/
Expand All @@ -24,7 +24,7 @@
#include "number.h"
#include "mathematics.h"

/******************** Array variable routines **************************/

/* fill array with a constant */
void fill_int_array(const ARRAY *arr, const int inh) {
int anz=anz_eintraege(arr);
Expand Down Expand Up @@ -70,7 +70,6 @@ void fill_array_array(const ARRAY *arr, const ARRAY inh) {

/********************* ARRAY Structure Routines ************************/
/* create array (need to be freed later) and fill it with a constant value */
/* Erzeuge jeweils entsprechendes Array und belege es mit value vor. */

ARRAY create_int_array(const uint32_t dimension, const uint32_t *dimlist,const int value) {
ARRAY ergebnis;
Expand Down Expand Up @@ -150,9 +149,6 @@ ARRAY create_string_array(const uint32_t dimension,const uint32_t *dimlist,const
}





ARRAY create_array_array(const uint32_t dimension, const uint32_t *dimlist,const ARRAY *value) {
ARRAY ergebnis;
int anz=1,j;
Expand Down Expand Up @@ -210,12 +206,12 @@ ARRAY create_array(const unsigned short typ, const uint32_t dimension, const uin
}
return(ergebnis);
}
/* Erzeuge ein Array und fuelle es soweit möglich mit Inhalt aus einem anderen Array.
/* Erzeuge ein Array und fuelle es soweit moeglich mit Inhalt aus einem anderen Array.
Erweitere mit 0 bzw mit Strings von Laenge 0
oder Arrays mit NOTYP und dimension 0
Es geht noch nicht: Bei mehrdimensionalen Arrays verschieben sich die Elemente.
Wenn die Dimension geanedert wird, was sollen wir tun?
Wenn die Dimension geaendert wird, was sollen wir tun?
Expand Down Expand Up @@ -402,15 +398,15 @@ ARRAY convert_to_xarray(const ARRAY *a,int rt) {
}
return(double_array(a));
}

/***********clone an array structure **********************/
/* Kopiert ein Array */

ARRAY double_array(const ARRAY *a) {
int anz=anz_eintraege(a);
ARRAY b=*a;
int size=b.dimension*INTSIZE+anz*typlaenge(b.typ);
// printf("double array: %p/%p\n",a,a->pointer);
b.pointer=malloc(size);
// printf(" array: %p --> %p\n",a->pointer,b.pointer);
memcpy(b.pointer,a->pointer,size);
if(b.typ==STRINGTYP) {
STRING *ppp1=(STRING *)(b.pointer+b.dimension*INTSIZE);
Expand Down Expand Up @@ -626,7 +622,7 @@ ARRAY mul_array(ARRAY a1, ARRAY a2) {
/*Pointer auf daten bestimmen*/
ar1=a1.pointer+a1.dimension*INTSIZE;
ar2=a2.pointer+a2.dimension*INTSIZE;
/*Dimension des Ergebnisses bestimmen, pointer auf daten des ergebnisses*/
/*Dimension des Ergebnisses bestimmen, pointer auf Daten des Ergebnisses*/
s3=s1;
if(s1<=1) ergebnis.dimension=0;
else ergebnis.dimension=2;
Expand Down Expand Up @@ -683,7 +679,7 @@ ARRAY trans_array(ARRAY a) {
a.pointer+a.dimension*INTSIZE+(j*((int *)b.pointer)[0]+i)*size,size);
}
}
} else xberror(85,"TRANS"); /* Transposition nur für zweidimensionale Matrizen.*/
} else xberror(85,"TRANS"); /* Transposition nur fuer zweidimensionale Matrizen.*/
return(b);
}

Expand Down Expand Up @@ -1151,7 +1147,7 @@ ARRAY get_subarray(ARRAY *arr,int *indexliste) {
}

/*Aindex sind die Dims fuer jede Dimension
Bindex ist die Liste der dims fuer die Dimensionen, welche ubertragen werden*/
Bindex ist die Liste der dims fuer die Dimensionen, welche uebertragen werden*/

//printf("get_subarray: adim=%d dim2=%d anz=%d\n",adim,dim2,anz);

Expand All @@ -1162,7 +1158,7 @@ ARRAY get_subarray(ARRAY *arr,int *indexliste) {
memcpy(ergebnis.pointer,bindex,dim2*sizeof(int));


/*bindex wird jetzt überschrieben*/
/*bindex wird jetzt ueberschrieben*/

/*Loop fuer die Komprimierung */
for(j=0;j<anz;j++) {
Expand Down Expand Up @@ -1232,14 +1228,15 @@ int make_indexliste(int dim, char *pos, int *index) {
flag=1;
break;
}
if(*w1==':' || *w1==0) {index[i]=-1;flag=1;}
if(*w1==':' || *w1==0) {index[i]=-1;flag=1;}
else if(searchchr3(w1,':')) {index[i]=-1;flag=1;} /* Suche Doppelpunkt auf der ersten Ebene in String.*/
else index[i]=(int)parser(w1);
e=wort_sep(w2,',',TRUE,w1,w2);
}
return(flag);
}

/*Überprüft Indexliste auf Fehler*/
/*Ueberprueft Indexliste auf Fehler*/
int check_indexliste(const ARRAY *a, const int *idx) {
int dim=a->dimension;
int *bbb=(int *)a->pointer;
Expand Down Expand Up @@ -1283,7 +1280,7 @@ int idx2idx(int jj,const ARRAY *a,int *idx, int *idx2) {
#endif


/* Liest ein Arrayelement anhand Indizies. */
/* Liest ein Arrayelement anhand der Indizies. */

int int_array_element(const ARRAY *a, int *idx) {
int ndim=0,anz=0;
Expand Down Expand Up @@ -1343,13 +1340,11 @@ ARRAY array_array_element(const ARRAY *a, int *idx) {

/*********** Subarray functions ****************/

/*bestimmt die dimension eines Subarrays anhand der indexliste*/
/* bestimmt die Dimension eines Subarrays anhand der Indexliste*/
int subarraydimf(int *indexliste, int n) {
int dim=0;
if(indexliste) {
while(--n>=0) { if(indexliste[n]<0) dim++; }
}
return dim;
}


4 changes: 3 additions & 1 deletion src/parameter.c
Original file line number Diff line number Diff line change
Expand Up @@ -295,7 +295,9 @@ void dump_parameterlist(PARAMETER *p, int n) {
case PL_LABEL: printf(" <label>\n");break;
case PL_PROC: printf(" <proc>\n");break;
case PL_FUNC: printf(" <func>\n");break;
case PL_ARRAY: printf(" <array,$%x,dim=%d>\n",p[j].arraytyp,p[j].integer);break;
case PL_ARRAY:
case PL_FARRAY:
case PL_IARRAY: printf(" <array,$%x,dim=%d>\n",p[j].arraytyp,p[j].integer);break;
case PL_FVAR: printf(" <var,%d,%s>\n",p[j].integer,variablen[p[j].integer].name);break;
case PL_CVAR: printf(" <var#,%d,%s>\n",p[j].integer,variablen[p[j].integer].name);break;
case PL_AIVAR: printf(" <var&,%d,%s>\n",p[j].integer,variablen[p[j].integer].name);break;
Expand Down
20 changes: 9 additions & 11 deletions src/type.c
Original file line number Diff line number Diff line change
Expand Up @@ -305,12 +305,17 @@ unsigned int type(const char *ausdruck) {
}


/* hier ist nun nurnoch ein operand zu untersuchen */
/* evaluate brackets */

if(*s=='(' && s[strlen(s)-1]==')') {
s[strlen(s)-1]=0;
return(type(s+1));
}

/* hier ist nun nurnoch ein operand zu untersuchen */



int typ=0;
int i=0;
pos=searchchr(s,'(');
Expand All @@ -319,7 +324,7 @@ unsigned int type(const char *ausdruck) {
if(pos==s) printf("WARNING: Syntax-error in expression: parenthesis? <%s>\n",s);
/* jetzt entscheiden, ob Array-element oder sub-array oder Funktion */
char *ppp=pos+1;
int i=0,flag=0,sflag=0,count=0;
int i=0;
*pos=0;
if((i=find_func(s))!=-1) { /* Koennte funktion sein: */
if(ppp[strlen(ppp)-1]==')') ppp[strlen(ppp)-1]=0;
Expand Down Expand Up @@ -348,15 +353,8 @@ unsigned int type(const char *ausdruck) {
return(typ);
} else { /* wird wohl Array sein.*/
if(pos[1]==')') typ=(typ | ARRAYTYP);
else {
while(ppp[i]!=0 && !(ppp[i]==')' && flag==0 && sflag==0)) { /*Fine doppelpunkte in Argumentliste*/
if(ppp[i]=='(') flag++;
if(ppp[i]==')') flag--;
if(ppp[i]=='"') sflag=(!sflag);
if(ppp[i]==':' && flag==0 && sflag==0) count++;
i++;
}
if(count) typ=(typ | ARRAYTYP);
else {/* Finde Doppelpunkte in Argumentliste, dann ist es auf jeden Fall ein Array, sonst nur array-element.*/
if(searchchr3(ppp, ':')) typ=(typ | ARRAYTYP);
}
}
} /* Kann auch @-Funktionsergebnis sein */
Expand Down

0 comments on commit a4d84f3

Please sign in to comment.