-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy paths3eGooglePlayGames.s4e
189 lines (147 loc) · 5.38 KB
/
s3eGooglePlayGames.s4e
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
# Google Play Games extension for Marmalade
include:
#include <s3eTypes.h>
#include "IwDebug.h"
/**
* @author David Hunt (Units of a Human) for Fluid Games
*/
/**
* @name Google Play Games extension for Marmalade
*/
/**
* Note In Marmalade all callbacks are queued up and trigger after the next s3eDeviceYield()
*
* Your callback needs to be of the form int32 MyCallback(void *systemData,void *userData)
* You can specify userData when you register the callback, it is simply passed back to your callback and
* could be used to help the callback identify context.
* The return value you set is ignored in all cases.
* You can register by passing an s3eCallback format function to the s3eGCRegisterCallback function.
* systemData has the following meaning depending on the specific callback.
*
*/
enum s3eGPGCallbackType
{
/**
* Initialization callback - systemData is a (s3eGPGInitializationResult*)
*/
S3EGPG_INITIALIZATION,
S3EGPG_MAX_ID
};
/**
* Enum of values indicating asynchronous initialization status
* (extension note : needs to be kept in synch with the Java GoogleGameStatus enum)
*/
enum s3eGPGInitializationResultEnum
{
/**
* The service is in the process of initializing.
*/
INITIALIZING,
/**
* The user successfully signed in and we're connected
*/
SERVICE_CONNECTED,
/**
* The user failed to connect, see the errorMsg parameter on s3eGPGInitializationResult
*/
SERVICE_FAILED,
/**
* The License Check failed. Android only, will only happen if you've enabled anti-piracy.
*/
SERVICE_YARRRR
};
/**
* Structure passed back to the S3EGPG_INITIALIZATION callback.
*
* @param error - boolean indicating if an error was returned
* @param errorMsg - a diagnostic string that will be empty if no error
*/
struct s3eGPGInitializationResult
{
s3eGPGInitializationResultEnum status;
const char* errorMsg;
};
functions:
/**
* @name Initialisation of Google Play Games
*/
/**
* Initialize the Google Play Games extension and then attempt to log the user in.
*
* This should be in response to a user initiated request to login the first time - see Google sing in guidelines.
* Initialization will take place asynchronously, you need to register for the S3EGPG_INITIALIZATION callback to check for completion.
*/
s3eResult s3eGPGInitialize() S3E_RESULT_ERROR run_on_os_thread
/**
* Close down Google Play Games
* This should be called if you no longer need the service regardless of the completion status of Initialize
*/
void s3eGPGDeInitialize() run_on_os_thread
/**
* Function to register your callbacks that the Google Games service will call on certain events
*
* note Callbacks are queued up and trigger after the next s3eDeviceYield().
* @param callbackID A member of the s3eGPGCallbackType enum
* @param callbackFn Your s3eCallback format function see callback definitions above for specifics
* @param userData Optional opaque pointer you can provide that will be passed back to your callback function in the userData parameter, this is for your convenience to provide context to your callback
* the extension doesn't know or care what it points at.
*/
void s3eGPGRegisterCallback(s3eGPGCallbackType callbackID,s3eCallback callbackFn,void* userData) run_on_os_thread
/**
* Function to unregister a previously registered callback.
*
* @param callbackID A member of the s3eGPGCallbackType enum
* @param callbackFn Your s3eCallback format function see callback definitions above for specifics
*/
void s3eGPGUnRegisterCallback(s3eGPGCallbackType callbackID,s3eCallback callbackFn) run_on_os_thread
/**
* @name Achievements
*/
/**
* Unlock a named Achievement using the name field you entered in Google Play Games console
*
* @param id - the ID string of the achievement
*/
void s3eGPGUnlockAchievement(const char* id) run_on_os_thread
/**
* Increment a named Achievement usimg the name field you entered in Google Play Games console
*
* Use this call with the "incremental" type of achievements.
* @param id - the ID string of the achievement
* @param increment - the amount to increase by (typically 1)
*/
void s3eGPGUnlockIncrementalAchievement(const char* id,int increment) run_on_os_thread
/**
* Display the default achievements UI. Your App will go into the background while this is showing.
*/
void s3eGPGShowAchievementsUI() run_on_os_thread
/**
* @name Achievements
*/
/**
* Submit a score to a leaderboard for this user.
*
* Pass the ID of the Leaderboard you created in the Google Play Games console
*
* Implementation Note : While Google Play Games supports 64 bit scores Marmalade can't pass int64_t (long) through s3eEdkThreadRunOnOS and so we fallback to int,
* bear this in mind while designing you leaderboards.
*
* @param leaderboardID - a string identifying the leaderboard you set up in the Google Play console.
* @param score - an integer score to submit
*/
void s3eGPGSubmitLeaderboardScore(const char* leaderboardID, int score) run_on_os_thread
/**
* Display a leaderboard
*
* @param leaderboardID - a string identifying the leaderboard you set up in the Google Play console. Your App will go into the background while this is showing.
*/
void s3eGPGShowLeaderboardUI(const char* leaderboardID) run_on_os_thread
/**
* Check if the user is signed in
*/
bool s3eGPGIsSignedIn() 0
/**
* Display the list of leaderboards for the game
*
*/
void s3eGPGShowAllLeaderBoardsUI() run_on_os_thread