/*
  !!DESCRIPTION!! pointer test
  !!ORIGIN!!
  !!LICENCE!!     public domain
*/

#include "common.h"
#include <stdio.h>

/*
  check behaviour on incompletely declared arrays
*/

char i1[];

void test1(void) {
int a;

	a=sizeof(i1[0]);
	printf("%04x - ",a);
	if(sizeof(i1[0])==sizeof(char)) {
		/* gcc gives size of element */
		printf("sizeof(i1[0]) gives size of element\n");
	}
	if(sizeof(i1[0])==sizeof(char*)) {
		printf("sizeof(i1[0]) gives size of pointer to element\n");
	}
}

/*
  check behaviour on string init
*/

char t1[]="abcde";
char t2[]={"abcde"};

char *t3="abcde";
char *t4={"abcde"};

void test2(void) {
char c1,c2,c3,c4;
int i,e=0;
	for(i=0;i<5;i++){
		c1=t1[i];c2=t2[i];c3=t3[i];c4=t4[i];
/*		printf("%02x %02x %02x %02x\n",c1,c2,c3,c4); */
		printf("%c %c %c %c\n",c1,c2,c3,c4);
		if(!((c1==c2)&(c1==c3)&(c1==c4))) e=1;
	}
	if(e) printf("test2 failed.\n");
	else printf("test2 ok.\n");
}

/*
  check behaviour on extern-declarations inside functions
*/

typedef struct {
  char *name;
  void *func;
} A3;

#ifdef NO_SLOPPY_STRUCT_INIT
A3 a3[] = {
  { "test3", (void*) NULL },
  { "test3", (void*) NULL },
};
#else
/*gcc warning: missing braces around initializer (near initialization for `a3[0]')
  this type of struct-initialization seems to be kinda common */
A3 a3[] = {
    "test3", (void*) NULL  ,
    "test3", (void*) NULL  ,
};
#endif

void test3a(A3 *list, int number){
	printf("%s %d\n",list->name,number);
}

static void test31(void)
{
    extern A3 a3[];
    test3a(a3, -1);
}

#if 0
/* this variation compiles and works with cc65, but gives an error with gcc :=P */
static void test32(void)
{
    extern A3 *a3;
    test3a(a3, -1);
}
#endif

static void test30(void)
{
    test3a(a3, -1);
}

/*
  todo: add test on function pointers in the form of (*func)(arg) ...
  cc65 seems to have problems here aswell ;/
*/

int main(void) {
  	test1();
	test2();
	test30();
	test31();
/*	test32(); */
	return 0;
}