Imported Upstream version 0.3.17
[platform/upstream/liboil.git] / testsuite / proto4.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 n;
42
43   oil_init ();
44
45   n = oil_class_get_n_classes ();
46   for (i=0;i<n; i++ ){
47     klass = oil_class_get_by_index(i);
48
49     if(klass->prototype) {
50       OilPrototype *proto;
51       char *string;
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       string = oil_prototype_to_string (proto);
60
61       printf("%s (%s)\n", klass->name, string);
62
63       oil_prototype_free (proto);
64       free(string);
65     } else {
66       printf("ERROR no prototype for %s\n", klass->name);
67     }
68   }
69
70   return 0;
71 }
72
73