@define listref(l, i){ if(i == 0) return car(l); else return listref(cdr(l), i-1); } @define mkzas(len){ @local dispatch, str; str = mkstr(len); @define dispatch(args ...) { @local arg, range, new, beg, end; arg = listref(args, 1); if(arg == "get"){ range = listref(args, 2); beg = rangebeg(range); end = beg+rangelen(range); printf("get %x %x\n", beg, end); return substr(str, beg, end); } if(arg == "put"){ range = listref(args, 2); beg = rangebeg(range); end = beg+rangelen(range); new = listref(args, 3); strput(str, beg, new); printf("put %x %x\n", beg, end); return; } printf("bad argument to dispatch!\n"); } return mkas([ "dispatch" : dispatch ]); } @define main(){ @local dom, ns, as; as = mkzas(1024); ns = @names c32le { struct foo { @0x0 int i; @0x4 int *p; @0x8; }; @0x0 int x; @0x4 int y; @0x8 struct foo foo; @0x10 struct foo a[3]; }; dom = mkdom(ns, as); // x = (dom`a[2].i)++; printf("sizeof(3) == %d\n", sizeof(3)); printf("sizeof(dom`a) == %d\n", sizeof(dom`a)); printf("sizeof(dom`a[2]) == %d\n", sizeof(dom`a[2])); printf("sizeof(dom`a[2].i) == %d\n", sizeof(dom`a[2].i)); } main();