Mercurial > sdl-ios-xcode
annotate src/main/beos/SDL_BeApp.cc @ 1338:604d73db6802
Removed uses of stdlib.h and string.h
author | Sam Lantinga <slouken@libsdl.org> |
---|---|
date | Tue, 07 Feb 2006 09:29:18 +0000 |
parents | c9b51268668f |
children | 376665398b25 |
rev | line source |
---|---|
0 | 1 /* |
2 SDL - Simple DirectMedia Layer | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
855
diff
changeset
|
3 Copyright (C) 1997-2006 Sam Lantinga |
0 | 4 |
5 This library is free software; you can redistribute it and/or | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
855
diff
changeset
|
6 modify it under the terms of the GNU Lesser General Public |
0 | 7 License as published by the Free Software Foundation; either |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
855
diff
changeset
|
8 version 2.1 of the License, or (at your option) any later version. |
0 | 9 |
10 This library is distributed in the hope that it will be useful, | |
11 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
855
diff
changeset
|
13 Lesser General Public License for more details. |
0 | 14 |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
855
diff
changeset
|
15 You should have received a copy of the GNU Lesser General Public |
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
855
diff
changeset
|
16 License along with this library; if not, write to the Free Software |
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
855
diff
changeset
|
17 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
0 | 18 |
19 Sam Lantinga | |
252
e8157fcb3114
Updated the source with the correct e-mail address
Sam Lantinga <slouken@libsdl.org>
parents:
0
diff
changeset
|
20 slouken@libsdl.org |
0 | 21 */ |
22 | |
23 /* Handle the BeApp specific portions of the application */ | |
24 | |
25 #include <AppKit.h> | |
26 #include <storage/Path.h> | |
27 #include <storage/Entry.h> | |
28 #include <unistd.h> | |
29 | |
30 #include "SDL_BeApp.h" | |
31 #include "SDL_thread.h" | |
32 #include "SDL_timer.h" | |
33 #include "SDL_error.h" | |
34 | |
35 /* Flag to tell whether or not the Be application is active or not */ | |
36 int SDL_BeAppActive = 0; | |
37 static SDL_Thread *SDL_AppThread = NULL; | |
38 | |
39 static int StartBeApp(void *unused) | |
40 { | |
41 BApplication *App; | |
42 | |
43 App = new BApplication("application/x-SDL-executable"); | |
44 | |
45 App->Run(); | |
46 delete App; | |
47 return(0); | |
48 } | |
49 | |
50 /* Initialize the Be Application, if it's not already started */ | |
51 int SDL_InitBeApp(void) | |
52 { | |
53 /* Create the BApplication that handles appserver interaction */ | |
54 if ( SDL_BeAppActive <= 0 ) { | |
55 SDL_AppThread = SDL_CreateThread(StartBeApp, NULL); | |
56 if ( SDL_AppThread == NULL ) { | |
57 SDL_SetError("Couldn't create BApplication thread"); | |
58 return(-1); | |
59 } | |
60 | |
855
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
61 /* Change working to directory to that of executable */ |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
62 app_info info; |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
63 if (B_OK == be_app->GetAppInfo(&info)) { |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
64 entry_ref ref = info.ref; |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
65 BEntry entry; |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
66 if (B_OK == entry.SetTo(&ref)) { |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
67 BPath path; |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
68 if (B_OK == path.SetTo(&entry)) { |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
69 if (B_OK == path.GetParent(&path)) { |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
70 chdir(path.Path()); |
0 | 71 } |
72 } | |
855
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
73 } |
aa4ac9e65d92
I noticed MacOSX SDL sets up working directory to parent of executable.
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
74 } |
0 | 75 |
76 do { | |
77 SDL_Delay(10); | |
78 } while ( (be_app == NULL) || be_app->IsLaunching() ); | |
79 | |
80 /* Mark the application active */ | |
81 SDL_BeAppActive = 0; | |
82 } | |
83 | |
84 /* Increment the application reference count */ | |
85 ++SDL_BeAppActive; | |
86 | |
87 /* The app is running, and we're ready to go */ | |
88 return(0); | |
89 } | |
90 | |
91 /* Quit the Be Application, if there's nothing left to do */ | |
92 void SDL_QuitBeApp(void) | |
93 { | |
94 /* Decrement the application reference count */ | |
95 --SDL_BeAppActive; | |
96 | |
97 /* If the reference count reached zero, clean up the app */ | |
98 if ( SDL_BeAppActive == 0 ) { | |
99 if ( SDL_AppThread != NULL ) { | |
100 if ( be_app != NULL ) { /* Not tested */ | |
101 be_app->PostMessage(B_QUIT_REQUESTED); | |
102 } | |
103 SDL_WaitThread(SDL_AppThread, NULL); | |
104 SDL_AppThread = NULL; | |
105 } | |
106 /* be_app should now be NULL since be_app has quit */ | |
107 } | |
108 } |