diff --git a/autobuild.xml b/autobuild.xml index 6a71eadbff9e0853ea9139ad0abd03155c3eb7a9..c25d995334169e072da49b2871901aa5b01264c8 100644 --- a/autobuild.xml +++ b/autobuild.xml @@ -614,16 +614,18 @@ <key>archive</key> <map> <key>hash</key> - <string>d85a32d905b199534e8feafa34b28e39</string> + <string>3a1bf9b1ded325f872fefa4ade23efd8</string> + <key>hash_algorithm</key> + <string>md5</string> <key>url</key> - <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/62332/588168/dullahan-1.7.0.202006241556_81.3.10_gb223419_chromium-81.0.4044.138-windows64-544091.tar.bz2</string> + <string>https://pkg.alchemyviewer.org/repository/autobuild-external/dullahan/windows64/dullahan-1.7.0.202009180903_85.3.9_gb045a6e_chromium-85.0.4183.102-windows64-342.tar.bz2</string> </map> <key>name</key> <string>windows64</string> </map> </map> <key>version</key> - <string>1.7.0.202006240858_81.3.10_gb223419_chromium-81.0.4044.138</string> + <string>1.7.0.202009180903_85.3.9_gb045a6e_chromium-85.0.4183.102</string> </map> <key>elfio</key> <map> diff --git a/indra/llplugin/llpluginclassmedia.cpp b/indra/llplugin/llpluginclassmedia.cpp index 6712a1f6bd250689fffec81cd1af4033fd685137..d7423eb1ffc44679624048fdc98b1162ed92cc87 100644 --- a/indra/llplugin/llpluginclassmedia.cpp +++ b/indra/llplugin/llpluginclassmedia.cpp @@ -856,6 +856,18 @@ void LLPluginClassMedia::paste() sendMessage(message); } +void LLPluginClassMedia::setCEFProgramDirs(const std::string& helper_path, + const std::string& resources_path, + const std::string& locales_path) +{ + LLPluginMessage message(LLPLUGIN_MESSAGE_CLASS_MEDIA, "set_cef_data_path"); + message.setValue("helper_path", helper_path); + message.setValue("resources_path", resources_path); + message.setValue("locales_path", locales_path); + + sendMessage(message); +} + void LLPluginClassMedia::setUserDataPath(const std::string &user_data_path_cache, const std::string &user_data_path_cookies, const std::string &user_data_path_cef_log) diff --git a/indra/llplugin/llpluginclassmedia.h b/indra/llplugin/llpluginclassmedia.h index 9d11ee0421d92f4b2efdaa28a8f800195be9aaa4..99d5e8cb692aa90f35b92196b443daf1709712ae 100644 --- a/indra/llplugin/llpluginclassmedia.h +++ b/indra/llplugin/llpluginclassmedia.h @@ -195,6 +195,7 @@ class LLPluginClassMedia : public LLPluginProcessParentOwner bool canPaste() const { return mCanPaste; }; // These can be called before init(), and they will be queued and sent before the media init message. + void setCEFProgramDirs(const std::string& helper_path, const std::string& resources_path = std::string(), const std::string& locales_path = std::string()); void setUserDataPath(const std::string &user_data_path_cache, const std::string &user_data_path_cookies, const std::string &user_data_path_cef_log); void setLanguageCode(const std::string &language_code); void setPluginsEnabled(const bool enabled); diff --git a/indra/media_plugins/cef/media_plugin_cef.cpp b/indra/media_plugins/cef/media_plugin_cef.cpp index bc967c9bcaf487db130af3123e201b7bd04699f3..ecd48daee2f893490dd7e01fccdd1f641f2fc207 100644 --- a/indra/media_plugins/cef/media_plugin_cef.cpp +++ b/indra/media_plugins/cef/media_plugin_cef.cpp @@ -83,6 +83,9 @@ class MediaPluginCEF : void checkEditState(); void setVolume(); + std::string mHelperPath; + std::string mResourcesPath; + std::string mLocalesPath; bool mEnableMediaPluginDebugging; std::string mHostLanguage; bool mCookiesEnabled; @@ -534,14 +537,12 @@ void MediaPluginCEF::receiveMessage(const char* message_string) settings.disable_network_service = mDisableNetworkService; settings.use_mock_keychain = mUseMockKeyChain; #endif - settings.flash_enabled = mPluginsEnabled; settings.flip_mouse_y = false; settings.flip_pixels_y = true; settings.frame_rate = 60; settings.force_wave_audio = true; settings.initial_height = 1024; settings.initial_width = 1024; - settings.java_enabled = false; settings.javascript_enabled = mJavascriptEnabled; settings.media_stream_enabled = false; // MAINT-6060 - WebRTC media removed until we can add granualrity/query UI settings.plugins_enabled = mPluginsEnabled; @@ -551,6 +552,11 @@ void MediaPluginCEF::receiveMessage(const char* message_string) settings.log_verbose = mCefLogVerbose; settings.autoplay_without_gesture = true; + // Set subprocess helper and cef app data paths + settings.browser_subprocess_path = mHelperPath; + settings.resources_dir_path = mResourcesPath; + settings.locales_dir_path = mLocalesPath; + std::vector<std::string> custom_schemes(1, "secondlife"); mCEFLib->setCustomSchemes(custom_schemes); @@ -580,6 +586,16 @@ void MediaPluginCEF::receiveMessage(const char* message_string) message.setValueBoolean("coords_opengl", true); sendMessage(message); } + else if (message_name == "set_cef_data_path") + { + std::string data_path_helper = message_in.getValue("helper_path"); + std::string data_path_resources = message_in.getValue("resources_path"); + std::string data_path_locales = message_in.getValue("locales_path"); + + mHelperPath = data_path_helper; + mResourcesPath = data_path_resources; + mLocalesPath = data_path_locales; + } else if (message_name == "set_user_data_path") { std::string user_data_path_cache = message_in.getValue("cache_path"); diff --git a/indra/newview/llviewermedia.cpp b/indra/newview/llviewermedia.cpp index 3ccb7977ab1abcc339c38cb467c831f2d622d2a9..22b433b854d8d92bf5a68e5e4331758f1ae69e6f 100644 --- a/indra/newview/llviewermedia.cpp +++ b/indra/newview/llviewermedia.cpp @@ -1754,6 +1754,10 @@ LLPluginClassMedia* LLViewerMediaImpl::newSourceFromMediaType(std::string media_ { media_source = new LLPluginClassMedia(owner); media_source->setSize(default_width, default_height); +#if LL_WINDOWS + std::string subprocess_folder = gDirUtilp->getLLPluginDir() + gDirUtilp->getDirDelimiter(); + media_source->setCEFProgramDirs(subprocess_folder); +#endif media_source->setUserDataPath(user_data_path_cache, user_data_path_cookies, user_data_path_cef_log); media_source->setLanguageCode(LLUI::getLanguage()); media_source->setZoomFactor(zoom_factor); diff --git a/indra/newview/viewer_manifest.py b/indra/newview/viewer_manifest.py index e03944ade76e380abc17e7c3a48a760076c4a445..fecc9b0baefdb8a89aa800a7f57ce3e79a03a4d4 100755 --- a/indra/newview/viewer_manifest.py +++ b/indra/newview/viewer_manifest.py @@ -630,6 +630,11 @@ def construct(self): self.path("snapshot_blob.bin") self.path("v8_context_snapshot.bin") + # CEF software renderer files + with self.prefix(src=os.path.join(pkgdir, 'bin', config, 'swiftshader'), dst='swiftshader'): + self.path("libEGL.dll") + self.path("libGLESv2.dll") + # CEF files common to all configurations with self.prefix(src=os.path.join(pkgdir, 'resources')): self.path("cef.pak")