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
92
93
94
95
96
|
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 2007 Sun Microsystems, Inc. All rights reserved.
*
* The contents of this file are subject to the terms of either
* the GNU General Public License Version 2 only ("GPL") or
* the Common Development and Distribution License("CDDL")
* (collectively, the "License"). You may not use this file
* except in compliance with the License. You can obtain a copy
* of the License at www.sun.com/CDDL or at COPYRIGHT. See the
* License for the specific language governing permissions and
* limitations under the License. When distributing the software,
* include this License Header Notice in each file and include
* the License file at /legal/license.txt. If applicable, add the
* following below the License Header, with the fields enclosed
* by brackets [] replaced by your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*
* Contributor(s):
*
* If you wish your version of this file to be governed by
* only the CDDL or only the GPL Version 2, indicate your
* decision by adding "[Contributor] elects to include this
* software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice
* of license, a recipient has the option to distribute your
* version of this file under either the CDDL, the GPL Version
* 2 or to extend the choice of license to its licensees as
* provided above. However, if you add GPL Version 2 code and
* therefore, elected the GPL Version 2 license, then the
* option applies only if the new code is made subject to such
* option by the copyright holder.
*/
/* papiTypes.h - Policy Access API types */
#ifndef PAPITYPES_H_
#define PAPITYPES_H_
#ifdef __cplusplus
extern "C" {
#endif
/* opaque PAPI session handle */
typedef struct PAPI PAPI;
/* Status returned by PAPI functions */
typedef enum { PAPISuccess = 0,
PAPIConnectionFailure,
PAPIAuthenticationFailure,
PAPINoSuchComponentFailure,
PAPILDBFailure,
PAPIInvalidArg,
PAPIOutOfMemoryFailure,
PAPIUnknownFailure } PAPIStatus;
/* Notification stuff */
typedef enum { PAPIComponentAdd,
PAPIComponentModify,
PAPIComponentRemove } PAPIEventType;
typedef struct {
PAPIEventType eventType;
const char * componentName;
} PAPIEvent;
typedef void ( *PAPIListener )( const PAPIEvent * inEvent, void * inUserData );
typedef void * PAPIListenerId;
/* Connection state stuff */
typedef enum { PAPIConnected, PAPIDisconnected } PAPIConnectionState;
typedef void ( *PAPIConnectionListener )( PAPIConnectionState inState,
void * inUserData );
/* Layer stuff */
typedef struct PAPILayerList
{
const unsigned char * data;
int size;
const char * timestamp;
struct PAPILayerList * next;
} PAPILayerList;
typedef struct PAPIStringList
{
const char * data;
struct PAPIStringList * next;
} PAPIStringList;
#ifdef __cplusplus
}
#endif
#endif /* PAPITYPES_H_ */
|