summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormaf@google.com <maf@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-13 23:17:37 +0000
committermaf@google.com <maf@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-13 23:17:37 +0000
commitfb8d32aab3a33166d3c1814e295eeafbea97174b (patch)
tree333cebe6d64ed3edb2fc5a3d7ef03fe8f5dec1b1
parentebe89e0676c12a6ebccb35fef1611323d1b35afb (diff)
downloadchromium_src-fb8d32aab3a33166d3c1814e295eeafbea97174b.zip
chromium_src-fb8d32aab3a33166d3c1814e295eeafbea97174b.tar.gz
chromium_src-fb8d32aab3a33166d3c1814e295eeafbea97174b.tar.bz2
Changes needed to get Mac plugin gyp project build compiling and linking.
Review URL: http://codereview.chromium.org/165433 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@23375 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--o3d/build/common.gypi3
-rw-r--r--o3d/build/libs.gyp6
-rw-r--r--o3d/plugin/cross/async_loading.cc1
-rw-r--r--o3d/plugin/cross/main.cc6
-rw-r--r--o3d/plugin/cross/np_v8_bridge.cc3
-rw-r--r--o3d/plugin/mac/config_mac.mm3
-rw-r--r--o3d/plugin/mac/main_mac.mm4
-rw-r--r--o3d/plugin/mac/plugin_mac.mm48
-rw-r--r--o3d/plugin/plugin.gyp14
9 files changed, 58 insertions, 30 deletions
diff --git a/o3d/build/common.gypi b/o3d/build/common.gypi
index 1883836..ef49a52 100644
--- a/o3d/build/common.gypi
+++ b/o3d/build/common.gypi
@@ -68,11 +68,12 @@
'SK_BUILD_FOR_MAC',
],
'xcode_settings': {
+ 'WARNING_CFLAGS': ['-Wno-deprecated-declarations'],
'CFLAGS': ['-gstabs+',
'-fno-eliminate-unused-debug-symbols',
'-mmacosx-version-min=10.4'],
'WARNING_CXXFLAGS': ['-Wstrict-aliasing',
- '-Wno-deprecated'],
+ '-Wno-deprecated',],
},
},
},
diff --git a/o3d/build/libs.gyp b/o3d/build/libs.gyp
index 43daadb..88dba6b 100644
--- a/o3d/build/libs.gyp
+++ b/o3d/build/libs.gyp
@@ -19,6 +19,12 @@
{
'destination': '<(PRODUCT_DIR)',
'conditions' : [
+ [ 'OS=="mac"',
+ {
+ 'files': [
+ ],
+ },
+ ],
[ 'OS=="win"',
{
'files': [
diff --git a/o3d/plugin/cross/async_loading.cc b/o3d/plugin/cross/async_loading.cc
index dfcbcfe..e0f577f 100644
--- a/o3d/plugin/cross/async_loading.cc
+++ b/o3d/plugin/cross/async_loading.cc
@@ -228,7 +228,6 @@ void userglue_method_send(void *plugin_data,
PluginObject *plugin_object = static_cast<PluginObject *>(plugin_data);
StreamManager *stream_manager = plugin_object->stream_manager();
StreamManager::FinishedCallback *callback = NULL;
- bool result = false;
if (request->done()) {
request->set_success(false);
diff --git a/o3d/plugin/cross/main.cc b/o3d/plugin/cross/main.cc
index da16756..1d33da5 100644
--- a/o3d/plugin/cross/main.cc
+++ b/o3d/plugin/cross/main.cc
@@ -49,10 +49,10 @@ namespace o3d {
NPError NP_GetValue(void *instance, NPPVariable variable, void *value) {
switch (variable) {
case NPPVpluginNameString:
- *static_cast<char **>(value) = O3D_PLUGIN_NAME;
+ *static_cast<char **>(value) = const_cast<char*>(O3D_PLUGIN_NAME);
break;
case NPPVpluginDescriptionString:
- *static_cast<char **>(value) = O3D_PLUGIN_DESCRIPTION;
+ *static_cast<char **>(value) = const_cast<char*>(O3D_PLUGIN_DESCRIPTION);
break;
default:
return NPERR_INVALID_PARAM;
@@ -170,7 +170,7 @@ NPError EXPORT_SYMBOL OSCALL NP_GetEntryPoints(NPPluginFuncs *pluginFuncs) {
}
char * EXPORT_SYMBOL NP_GetMIMEDescription(void) {
- return O3D_PLUGIN_MIME_TYPE "::O3D MIME";
+ return const_cast<char*>(O3D_PLUGIN_MIME_TYPE "::O3D MIME");
}
} // namespace o3d / extern "C"
diff --git a/o3d/plugin/cross/np_v8_bridge.cc b/o3d/plugin/cross/np_v8_bridge.cc
index e36b9d8..2acdfd8 100644
--- a/o3d/plugin/cross/np_v8_bridge.cc
+++ b/o3d/plugin/cross/np_v8_bridge.cc
@@ -484,7 +484,8 @@ class NPV8Object : public NPObject {
// Due to a bug in Chrome, need to filter out any properties that
// are functions. See comment in HasProperty.
int num_non_function_properties = 0;
- for (int i = 0; i != v8_names->Length(); ++i) {
+ int length = v8_names->Length();
+ for (int i = 0; i < length; ++i) {
Local<Value> v8_property_value =
v8_object->Get(v8_names->Get(Int32::New(i)));
if (!v8_property_value->IsFunction()) {
diff --git a/o3d/plugin/mac/config_mac.mm b/o3d/plugin/mac/config_mac.mm
index 96701df..ec304da 100644
--- a/o3d/plugin/mac/config_mac.mm
+++ b/o3d/plugin/mac/config_mac.mm
@@ -174,7 +174,8 @@ bool UseSoftwareRenderer() {
NULL);
use_software_renderer = false;
- for (int i = 0; i < arraysize(softwareRenderList); ++i) {
+ int list_count = arraysize(softwareRenderList);
+ for (int i = 0; i < list_count; ++i) {
GPUInfo &softwareRenderInfo = softwareRenderList[i];
if (vendorID == softwareRenderInfo.vendorID
&& deviceID == softwareRenderInfo.deviceID) {
diff --git a/o3d/plugin/mac/main_mac.mm b/o3d/plugin/mac/main_mac.mm
index ac47bb0..5ec0777 100644
--- a/o3d/plugin/mac/main_mac.mm
+++ b/o3d/plugin/mac/main_mac.mm
@@ -530,7 +530,7 @@ NPError InitializePlugin() {
// Cannot actually fail -
void Mac_SetBestEventModel(NPP instance, PluginObject* obj) {
NPError err = NPERR_NO_ERROR;
- NPEventModel event_model = NPEventModelCarbon;
+ NPEventModel model_to_use = NPEventModelCarbon;
NPBool supportsCocoaEventModel = FALSE;
NPBool supportsCarbonEventModel = FALSE;
@@ -566,7 +566,7 @@ void Mac_SetBestEventModel(NPP instance, PluginObject* obj) {
// Cocoa event model spec does not supply sufficient window
// information in its Cocoa NPP_SetWindow calls for us to bind an
// AGL context to the browser window.
- NPEventModel model_to_use =
+ model_to_use =
(supportsCarbonEventModel) ? NPEventModelCarbon : NPEventModelCocoa;
NPN_SetValue(instance, NPPVpluginEventModel,
reinterpret_cast<void*>(model_to_use));
diff --git a/o3d/plugin/mac/plugin_mac.mm b/o3d/plugin/mac/plugin_mac.mm
index 0c46fe3..f04955d 100644
--- a/o3d/plugin/mac/plugin_mac.mm
+++ b/o3d/plugin/mac/plugin_mac.mm
@@ -213,7 +213,8 @@ void RenderTimer::RemoveInstance(NPP instance) {
void RenderTimer::TimerCallback(CFRunLoopTimerRef timer, void* info) {
HANDLE_CRASHES;
- for (int i = 0; i < instances_.size(); ++i) {
+ int instance_count = instances_.size();
+ for (int i = 0; i < instance_count; ++i) {
NPP instance = instances_[i];
PluginObject* obj = static_cast<PluginObject*>(instance->pdata);
@@ -383,10 +384,7 @@ static UniChar * GetFullscreenDisplayText(int *returned_length) {
static void DrawToOverlayWindow(WindowRef overlayWindow) {
CGContextRef overlayContext = NULL;
- OSStatus result = noErr;
CGFloat kWhiteOpaque[] = {1.0, 1.0, 1.0, 1.0};
- CGFloat kBlackOpaque[] = {0.0, 0.0, 0.0, 1.0};
- CGFloat kGreyNotOpaque[] = {0.5, 0.5, 0.5, 0.5};
CGFloat kBlackNotOpaque[] = {0.0, 0.0, 0.0, 0.5};
Rect bounds = {0, 0, 0, 0};
const char* kOverlayWindowFontName = "Arial";
@@ -536,8 +534,8 @@ static WindowRef CreateOverlayWindow(void) {
kWindowNoActivatesAttribute |
kWindowStandardHandlerAttribute;
EventTypeSpec eventTypes[] = {
- kEventClassWindow, kEventWindowPaint,
- kEventClassWindow, kEventWindowShown
+ {kEventClassWindow, kEventWindowPaint},
+ {kEventClassWindow, kEventWindowShown}
};
err = CreateNewWindow(wClass,
@@ -592,7 +590,6 @@ o3d::Event::Button MacOSMouseButtonNumberToO3DButton(int inButton) {
static OSStatus HandleFullscreenWindow(EventHandlerCallRef inHandlerCallRef,
EventRef inEvent,
void *inUserData) {
- OSStatus err = noErr;
OSType event_class = GetEventClass(inEvent);
OSType event_kind = GetEventKind(inEvent);
NPP instance = (NPP)inUserData;
@@ -717,6 +714,7 @@ static OSStatus HandleFullscreenWindow(EventHandlerCallRef inHandlerCallRef,
return eventNotHandledErr;
}
}
+ return noErr;
}
@@ -726,15 +724,15 @@ static WindowRef CreateFullscreenWindow(WindowRef window,
Rect bounds = CGRect2Rect(CGDisplayBounds(CGMainDisplayID()));
OSStatus err = noErr;
EventTypeSpec eventTypes[] = {
- kEventClassKeyboard, kEventRawKeyDown,
- kEventClassKeyboard, kEventRawKeyRepeat,
- kEventClassKeyboard, kEventRawKeyUp,
- kEventClassMouse, kEventMouseDown,
- kEventClassMouse, kEventMouseUp,
- kEventClassMouse, kEventMouseMoved,
- kEventClassMouse, kEventMouseDragged,
- kEventClassMouse, kEventMouseScroll,
- kEventClassMouse, kEventMouseWheelMoved
+ {kEventClassKeyboard, kEventRawKeyDown},
+ {kEventClassKeyboard, kEventRawKeyRepeat},
+ {kEventClassKeyboard, kEventRawKeyUp},
+ {kEventClassMouse, kEventMouseDown},
+ {kEventClassMouse, kEventMouseUp},
+ {kEventClassMouse, kEventMouseMoved},
+ {kEventClassMouse, kEventMouseDragged},
+ {kEventClassMouse, kEventMouseScroll},
+ {kEventClassMouse, kEventMouseWheelMoved}
};
if (window == NULL)
@@ -874,6 +872,10 @@ static void GetCurrentDisplayMode(o3d::DisplayMode *mode) {
}
+
+} // namespace o3d
+
+
bool PluginObject::GetDisplayMode(int id, o3d::DisplayMode *mode) {
if (id == o3d::Renderer::DISPLAY_MODE_DEFAULT) {
GetCurrentDisplayMode(mode);
@@ -896,10 +898,10 @@ void PluginObject::GetDisplayModes(std::vector<o3d::DisplayMode> *modes) {
int bpp = 0;
if (o3d::ExtractDisplayModeData([mac_modes objectAtIndex:i],
- &width,
- &height,
- &refresh_rate,
- &bpp) && bpp == 32)
+ &width,
+ &height,
+ &refresh_rate,
+ &bpp) && bpp == 32)
modes_found.push_back(o3d::DisplayMode(width, height, refresh_rate,
i + o3d::kO3D_MODE_OFFSET));
}
@@ -912,6 +914,9 @@ void PluginObject::GetDisplayModes(std::vector<o3d::DisplayMode> *modes) {
#define kTransitionTime 1.0
+namespace glue {
+namespace _o3d {
+
bool PluginObject::RequestFullscreenDisplay() {
// If already in fullscreen mode, do nothing.
if (GetFullscreenMacWindow())
@@ -943,7 +948,7 @@ bool PluginObject::RequestFullscreenDisplay() {
short short_target_width = target_width;
short short_target_height = target_height;
BeginFullScreen(&mac_fullscreen_state_,
- GetMainDevice(),
+ nil, // Value of nil selects the main screen.
&short_target_width,
&short_target_height,
&fullscreen_window,
@@ -1025,4 +1030,5 @@ void PluginObject::FullscreenIdle() {
}
}
+} // namespace glue
} // namespace o3d
diff --git a/o3d/plugin/plugin.gyp b/o3d/plugin/plugin.gyp
index e0065ae..b9e22ab 100644
--- a/o3d/plugin/plugin.gyp
+++ b/o3d/plugin/plugin.gyp
@@ -75,6 +75,9 @@
],
['OS == "mac"',
{
+ 'dependencies': [
+ '../../breakpad/breakpad.gyp:breakpad',
+ ],
'sources': [
'mac/config_mac.mm',
'mac/main_mac.mm',
@@ -82,13 +85,24 @@
'mac/plugin_logging-mac.mm',
'mac/plugin_mac.h',
'mac/plugin_mac.mm',
+ 'mac/graphics_utils_mac.mm',
+ ],
+ 'mac_framework_dirs': [
+ '../../breakpad/src/client/mac/build/Release',
],
'defines': [
'XP_MACOSX=1',
],
'link_settings': {
'libraries': [
+ '$(SDKROOT)/System/Library/Frameworks/AGL.framework',
'$(SDKROOT)/System/Library/Frameworks/Foundation.framework',
+ '$(SDKROOT)/System/Library/Frameworks/IOKit.framework',
+ '$(SDKROOT)/System/Library/Frameworks/OpenGL.framework',
+ '$(SDKROOT)/System/Library/Frameworks/QuickTime.framework',
+ '../../breakpad/src/client/mac/build/Release/Breakpad.framework',
+ '../../third_party/cg/files/mac/Cg.framework',
+ '../../third_party/glew/files/lib/libGLEW.a',
],
},
},