aboutsummaryrefslogtreecommitdiff
path: root/Examples/mzscheme/multimap/example.i
blob: 515948abc8db27900ab2f1f2901db9450a3523be (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/* File : example.i */
%module example

%{
extern int gcd(int x, int y);
extern int gcdmain(int argc, char *argv[]);
extern int count(char *bytes, int len, char c);
extern void capitalize (char *str, int len);
extern void circle (double cx, double cy);
extern int squareCubed (int n, int *OUTPUT);
%}

%include exception.i
%include typemaps.i

extern int    gcd(int x, int y);

%typemap(in) (int argc, char *argv[]) {
  int i;
  Scheme_Object **elms;
  if (!SCHEME_VECTORP($input)) {
    scheme_wrong_type("$name","vector",$argnum,argc,argv);
  }
  $1 = SCHEME_VEC_SIZE($input);
  elms = SCHEME_VEC_ELS($input);
  if ($1 == 0) {
    scheme_wrong_type("$name","vector",$argnum,argc,argv);
  }
  $2 = (char **) malloc(($1+1)*sizeof(char *));
  for (i = 0; i < $1; i++) {
    if (!SCHEME_STRINGP(elms[i])) {
      free($2);
      scheme_wrong_type("$name","vector",$argnum,argc,argv);      
    }
    $2[i] = SCHEME_STR_VAL(elms[i]);
  }
  $2[i] = 0;
}

%typemap(freearg) (int argc, char *argv[]) {
  free($2);
}
extern int gcdmain(int argc, char *argv[]);

%typemap(in) (char *bytes, int len) {
  if (!SCHEME_STRINGP($input)) {
     scheme_wrong_type("$name","string",1,argc,argv);
  }	
  $1 = SCHEME_STR_VAL($input);
  $2 = SCHEME_STRLEN_VAL($input);
}

extern int count(char *bytes, int len, char c);


/* This example shows how to wrap a function that mutates a string */

%typemap(in) (char *str, int len) {
  if (!SCHEME_STRINGP($input)) {
     scheme_wrong_type("$name","string",1,argc,argv);
  }	
  $2 = SCHEME_STRLEN_VAL($input);
  $1 = (char *) malloc($2+1);
  memmove($1,SCHEME_STR_VAL($input),$2);
}

/* Return the mutated string as a new object.  */

%typemap(argout) (char *str, int len) {
   Scheme_Object *s;
   s = scheme_make_sized_string($1,$2,1);
   SWIG_APPEND_VALUE(s);
   free($1);
}   

extern void capitalize(char *str, int len);

/* A multi-valued constraint.  Force two arguments to lie
   inside the unit circle */

%typemap(check) (double cx, double cy) {
   double a = $1*$1 + $2*$2;
   if (a > 1.0) {
	SWIG_exception(SWIG_ValueError,"$1_name and $2_name must be in unit circle");
        return NULL;
   }
}

extern void circle(double cx, double cy);