Update tizen 2.0 beta source
[profile/ivi/liboil.git] / testsuite / proto1.c
1 /*
2  * LIBOIL - Library of Optimized Inner Loops
3  * Copyright (c) 2004 David A. Schleef <ds@schleef.org>
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  * 
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
19  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
21  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
23  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
24  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25  * POSSIBILITY OF SUCH DAMAGE.
26  */
27
28
29 #include <stdio.h>
30 #include <liboil/liboil.h>
31 #include <ctype.h>
32 #include <stdlib.h>
33 #include <string.h>
34
35 #include <liboil/liboilprototype.h>
36
37 int main (int argc, char *argv[])
38 {
39   OilFunctionClass *klass;
40   int i;
41   int j;
42   int n;
43
44   oil_init ();
45
46   n = oil_class_get_n_classes ();
47   for (i=0;i<n; i++ ){
48     klass = oil_class_get_by_index(i);
49
50     if(klass->prototype) {
51       OilPrototype *proto;
52
53       proto = oil_prototype_from_string (klass->prototype);
54       if (proto == NULL) {
55         printf ("ERROR bad prototype for %s\n", klass->name);
56         continue;
57       }
58
59       for(j=0;j<proto->n_params;j++){
60         if (proto->params[j].parameter_type == OIL_ARG_UNKNOWN) {
61           printf("ERROR bad parameter %s(%s) [%s]\n", klass->name, klass->prototype,
62               proto->params[j].parameter_name);
63           break;
64         }
65       }
66       oil_prototype_free (proto);
67     } else {
68       printf("ERROR no prototype for %s\n", klass->name);
69     }
70   }
71
72   return 0;
73 }
74
75