diff --git a/.gitignore b/.gitignore index ebc7fe0304..e92d3bb6b8 100644 --- a/.gitignore +++ b/.gitignore @@ -41,3 +41,4 @@ x64/Release Win32/Release .vs/ /Help +/tools diff --git a/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.cpp b/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.cpp index 790a16c94e..dd9d47e85d 100644 --- a/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.cpp +++ b/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.cpp @@ -4,8 +4,8 @@ #include "stdafx.h" #include "JavascriptAsyncMethodHandler.h" -#include "../CefSharp.Core/Internals/Messaging/Messages.h" -#include "../CefSharp.Core/Internals/Serialization/Primitives.h" +#include "../CefSharp.Core.Runtime/Internals/Messaging/Messages.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/Primitives.h" #include "Serialization/V8Serialization.h" #include "CefAppUnmanagedWrapper.h" diff --git a/CefSharp.BrowserSubprocess.Core/BindObjectAsyncHandler.h b/CefSharp.BrowserSubprocess.Core/BindObjectAsyncHandler.h index 3d6203ad3e..f129cde0de 100644 --- a/CefSharp.BrowserSubprocess.Core/BindObjectAsyncHandler.h +++ b/CefSharp.BrowserSubprocess.Core/BindObjectAsyncHandler.h @@ -6,8 +6,8 @@ #include "include/cef_v8.h" #include "RegisterBoundObjectRegistry.h" -#include "..\CefSharp.Core\Internals\Messaging\Messages.h" -#include "..\CefSharp.Core\Internals\Serialization\Primitives.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" using namespace System; using namespace CefSharp::Internals::Messaging; diff --git a/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp b/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp index e35624f08d..c401cf89a6 100644 --- a/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp +++ b/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp @@ -19,8 +19,8 @@ #include "Wrapper\V8Context.h" #include "Wrapper\Frame.h" #include "Wrapper\Browser.h" -#include "..\CefSharp.Core\Internals\Messaging\Messages.h" -#include "..\CefSharp.Core\Internals\Serialization\Primitives.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" using namespace System; using namespace System::Diagnostics; diff --git a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.filters b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.filters index f16d2fabba..adeeecfd00 100644 --- a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.filters +++ b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.filters @@ -32,10 +32,10 @@ Header Files - + Header Files - + Header Files @@ -56,10 +56,10 @@ Header Files - + Header Files - + Header Files @@ -77,7 +77,7 @@ Header Files - + Header Files @@ -148,7 +148,7 @@ Source Files - + Source Files @@ -166,7 +166,7 @@ Source Files - + Source Files diff --git a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.vcxproj b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.vcxproj index 504c792576..0871ffc2fa 100644 --- a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.vcxproj +++ b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.netcore.vcxproj @@ -174,11 +174,11 @@ - - - - - + + + + + @@ -207,8 +207,8 @@ - - + + diff --git a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj index e211929c7c..d16a4876e8 100644 --- a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj +++ b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj @@ -1,6 +1,7 @@  + Debug @@ -167,11 +168,11 @@ - - - - - + + + + + @@ -208,8 +209,8 @@ - - + + @@ -247,5 +248,7 @@ - + + + \ No newline at end of file diff --git a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj.filters b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj.filters index 71c703e934..90832c8d34 100644 --- a/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj.filters +++ b/CefSharp.BrowserSubprocess.Core/CefSharp.BrowserSubprocess.Core.vcxproj.filters @@ -32,10 +32,10 @@ Header Files - + Header Files - + Header Files @@ -56,10 +56,10 @@ Header Files - + Header Files - + Header Files @@ -77,7 +77,7 @@ Header Files - + Header Files @@ -154,7 +154,7 @@ Source Files - + Source Files @@ -172,7 +172,7 @@ Source Files - + Source Files diff --git a/CefSharp.BrowserSubprocess.Core/JavascriptPostMessageHandler.h b/CefSharp.BrowserSubprocess.Core/JavascriptPostMessageHandler.h index 81fe6c0ea4..2ea73d8cc0 100644 --- a/CefSharp.BrowserSubprocess.Core/JavascriptPostMessageHandler.h +++ b/CefSharp.BrowserSubprocess.Core/JavascriptPostMessageHandler.h @@ -5,8 +5,8 @@ #pragma once #include "include/cef_v8.h" -#include "..\CefSharp.Core\Internals\Messaging\Messages.h" -#include "..\CefSharp.Core\Internals\Serialization\Primitives.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" #include "Serialization\V8Serialization.h" using namespace System; diff --git a/CefSharp.BrowserSubprocess.Core/JavascriptPromiseHandler.h b/CefSharp.BrowserSubprocess.Core/JavascriptPromiseHandler.h index 918d9d127b..bfde170538 100644 --- a/CefSharp.BrowserSubprocess.Core/JavascriptPromiseHandler.h +++ b/CefSharp.BrowserSubprocess.Core/JavascriptPromiseHandler.h @@ -5,8 +5,8 @@ #pragma once #include "include/cef_v8.h" -#include "..\CefSharp.Core\Internals\Messaging\Messages.h" -#include "..\CefSharp.Core\Internals\Serialization\Primitives.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" #include "Serialization\V8Serialization.h" using namespace System; diff --git a/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectHandler.h b/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectHandler.h index acfdbb5ea8..44d51fee12 100644 --- a/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectHandler.h +++ b/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectHandler.h @@ -6,8 +6,8 @@ #include "include/cef_v8.h" #include "RegisterBoundObjectRegistry.h" -#include "..\CefSharp.Core\Internals\Messaging\Messages.h" -#include "..\CefSharp.Core\Internals\Serialization\Primitives.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" using namespace System; using namespace CefSharp::Internals::Messaging; diff --git a/CefSharp.BrowserSubprocess.Core/Resource.rc b/CefSharp.BrowserSubprocess.Core/Resource.rc index 8e931a3681..9293f18921 100644 --- a/CefSharp.BrowserSubprocess.Core/Resource.rc +++ b/CefSharp.BrowserSubprocess.Core/Resource.rc @@ -1,6 +1,6 @@ 1 VERSIONINFO - FILEVERSION 86,0,20 - PRODUCTVERSION 86,0,20 + FILEVERSION 87,1,11 + PRODUCTVERSION 87,1,11 FILEFLAGSMASK 0x17L #ifdef _DEBUG FILEFLAGS 0x1L @@ -16,10 +16,10 @@ BEGIN BLOCK "040904b0" BEGIN VALUE "FileDescription", "CefSharp.BrowserSubprocess.Core" - VALUE "FileVersion", "86.0.20" + VALUE "FileVersion", "87.1.11" VALUE "LegalCopyright", "Copyright © 2020 The CefSharp Authors" VALUE "ProductName", "CefSharp" - VALUE "ProductVersion", "86.0.20" + VALUE "ProductVersion", "87.1.11" END END BLOCK "VarFileInfo" diff --git a/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.cpp b/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.cpp index 27b237ae80..64ef5b1424 100644 --- a/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.cpp +++ b/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.cpp @@ -4,8 +4,8 @@ #include "stdafx.h" #include "JsObjectsSerialization.h" -#include "../CefSharp.Core/Internals/Serialization/Primitives.h" -#include "../CefSharp.Core/Internals/Serialization/ObjectsSerialization.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/Primitives.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/ObjectsSerialization.h" namespace CefSharp { diff --git a/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.cpp b/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.cpp index a47b1286bf..9773b31fd9 100644 --- a/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.cpp +++ b/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.cpp @@ -1,11 +1,11 @@ -// Copyright © 2015 The CefSharp Authors. All rights reserved. +// Copyright © 2015 The CefSharp Authors. All rights reserved. // // Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. #include "Stdafx.h" #include "V8Serialization.h" #include "JavascriptCallbackRegistry.h" -#include "../CefSharp.Core/Internals/Serialization/Primitives.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/Primitives.h" #include @@ -185,4 +185,4 @@ namespace CefSharp template CefRefPtr DeserializeV8Object(const CefRefPtr& list, const CefString& index); } } -} \ No newline at end of file +} diff --git a/CefSharp.BrowserSubprocess.Core/Stdafx.h b/CefSharp.BrowserSubprocess.Core/Stdafx.h index fbdd796040..b450bb08cb 100644 --- a/CefSharp.BrowserSubprocess.Core/Stdafx.h +++ b/CefSharp.BrowserSubprocess.Core/Stdafx.h @@ -14,10 +14,10 @@ #include -#include ".\..\CefSharp.Core\Internals\MCefRefPtr.h" -#include ".\..\CefSharp.Core\Internals\StringUtils.h" +#include ".\..\CefSharp.Core.Runtime\Internals\MCefRefPtr.h" +#include ".\..\CefSharp.Core.Runtime\Internals\StringUtils.h" #include "vcclr_local.h" using namespace System; using namespace CefSharp; -using namespace CefSharp::Internals; \ No newline at end of file +using namespace CefSharp::Internals; diff --git a/CefSharp.BrowserSubprocess.Core/TypeUtils.cpp b/CefSharp.BrowserSubprocess.Core/TypeUtils.cpp index e8ea19b9b1..f0355f2321 100644 --- a/CefSharp.BrowserSubprocess.Core/TypeUtils.cpp +++ b/CefSharp.BrowserSubprocess.Core/TypeUtils.cpp @@ -5,7 +5,7 @@ #pragma once #include "Stdafx.h" -#include ".\..\CefSharp.Core\Internals\StringUtils.h" +#include ".\..\CefSharp.Core.Runtime\Internals\StringUtils.h" #include "TypeUtils.h" using namespace System::Collections::Generic; diff --git a/CefSharp.BrowserSubprocess.Core/packages.CefSharp.BrowserSubprocess.Core.config b/CefSharp.BrowserSubprocess.Core/packages.CefSharp.BrowserSubprocess.Core.config index c5acab68f2..913cc77c00 100644 --- a/CefSharp.BrowserSubprocess.Core/packages.CefSharp.BrowserSubprocess.Core.config +++ b/CefSharp.BrowserSubprocess.Core/packages.CefSharp.BrowserSubprocess.Core.config @@ -1,4 +1,5 @@  + \ No newline at end of file diff --git a/CefSharp.BrowserSubprocess/app.manifest b/CefSharp.BrowserSubprocess/app.manifest index bfa62ccd9e..851c929ff3 100644 --- a/CefSharp.BrowserSubprocess/app.manifest +++ b/CefSharp.BrowserSubprocess/app.manifest @@ -8,7 +8,7 @@ xmlns:asmv3="urn:schemas-microsoft-com:asm.v3" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> - + diff --git a/CefSharp.Core.Runtime.RefAssembly/CefSharp.Core.Runtime.RefAssembly.csproj b/CefSharp.Core.Runtime.RefAssembly/CefSharp.Core.Runtime.RefAssembly.csproj new file mode 100644 index 0000000000..fd7abad8e1 --- /dev/null +++ b/CefSharp.Core.Runtime.RefAssembly/CefSharp.Core.Runtime.RefAssembly.csproj @@ -0,0 +1,64 @@ + + + + + + Debug + AnyCPU + {6F1CD3B6-DA67-4563-A662-F88E81951A82} + Library + Properties + CefSharp.Core + CefSharp.Core.Runtime + v4.5.2 + 512 + + + + + 7.1 + + + true + + + ..\CefSharp.snk + + + true + bin\Debug\ + DEBUG;TRACE + full + AnyCPU + prompt + MinimumRecommendedRules.ruleset + + + bin\Release\ + TRACE + true + pdbonly + AnyCPU + prompt + MinimumRecommendedRules.ruleset + + + + + + + + + + + + + + + + {a55848cc-10e7-40cb-addb-04740b16dd43} + CefSharp + + + + \ No newline at end of file diff --git a/CefSharp.Core.RefAssembly/CefSharp.Core.RefAssembly.csproj b/CefSharp.Core.Runtime.RefAssembly/CefSharp.Core.Runtime.RefAssembly.netcore.csproj similarity index 62% rename from CefSharp.Core.RefAssembly/CefSharp.Core.RefAssembly.csproj rename to CefSharp.Core.Runtime.RefAssembly/CefSharp.Core.Runtime.RefAssembly.netcore.csproj index 9654975c51..2200761f77 100644 --- a/CefSharp.Core.RefAssembly/CefSharp.Core.RefAssembly.csproj +++ b/CefSharp.Core.Runtime.RefAssembly/CefSharp.Core.Runtime.RefAssembly.netcore.csproj @@ -1,8 +1,18 @@ - + + + + + obj.netcore\ + bin.netcore\ + + + + netcoreapp3.1 CefSharp.Core - CefSharp.Core + CefSharp.Core.Runtime $(BaseOutputPath)$(PlatformTarget)\$(Configuration)\$(TargetFramework)\$(AssemblyName).xml false true @@ -10,12 +20,25 @@ MinimumRecommendedRules.ruleset CS1591,CS0436 + + + + + + + + + + + + + - + false - + false @@ -31,21 +54,21 @@ Haven't found a nice way to determine the Platform (resolves as AnyCPU) --> - + - $(SolutionDir)CefSharp.Core\bin.netcore\x64\$(Configuration)\CefSharp.Core.dll + $(SolutionDir)CefSharp.Core.Runtime\bin.netcore\x64\$(Configuration)\CefSharp.Core.Runtime.dll - $(SolutionDir)CefSharp.Core\bin.netcore\win32\$(Configuration)\CefSharp.Core.dll + $(SolutionDir)CefSharp.Core.Runtime\bin.netcore\win32\$(Configuration)\CefSharp.Core.Runtime.dll false $(ProjectDir) - $(GenAPITargetDir)$(AssemblyName).cs + $(GenAPITargetDir)$(AssemblyName).netcore.cs + + obj.netcore\ + bin.netcore\ + + + + + + netcoreapp3.1 + CefSharp.Core + CefSharp.Core + $(BaseOutputPath)$(PlatformTarget)$(Configuration)\$(TargetFramework)\$(AssemblyName).xml + false + true + ..\CefSharp.snk + MinimumRecommendedRules.ruleset + CS1591,CS0436 + 9.0 + + + + DEBUG;TRACE;NETCOREAPP + + + + TRACE;NETCOREAPP + + + + + all + runtime; build; native; contentfiles; analyzers; buildtransitive + + + + + + false + + + false + + + + + \ No newline at end of file diff --git a/CefSharp.Core/Initializer.cs b/CefSharp.Core/Initializer.cs new file mode 100644 index 0000000000..e8c02dda0f --- /dev/null +++ b/CefSharp.Core/Initializer.cs @@ -0,0 +1,76 @@ +// Copyright © 2020 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +using System; +using System.IO; +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +namespace CefSharp +{ + /// + /// CLR Module Initializer + /// Used to load libcef.dll if required + /// + public static class Initializer + { + //TODO: Internal debugging only for now, needs improving if users are going to + //get meaningful data from this. + public static (bool Loaded, string Path, string BrowserSubProcessPath, IntPtr LibraryHandle) LibCefLoadStatus; + + [ModuleInitializer] + internal static void ModuleInitializer() + { + var currentFolder = Path.GetDirectoryName(Assembly.GetEntryAssembly().Location); + var libCefPath = Path.Combine(currentFolder, "libcef.dll"); + + if (File.Exists(libCefPath)) + { + //We didn't load CEF, it was already next to our calling assembly, the + //framework should load it correctly on it's own + LibCefLoadStatus = (false, libCefPath, null, IntPtr.Zero); + } + else + { + //TODO: This will need changing if we support ARM64 + var arch = Environment.Is64BitProcess ? "x64" : "x86"; + var archFolder = $"runtimes\\win-{arch}\\native"; + libCefPath = Path.Combine(currentFolder, archFolder, "libcef.dll"); + if (File.Exists(libCefPath)) + { + if (NativeLibrary.TryLoad(libCefPath, out IntPtr handle)) + { + var browserSubProcessPath = Path.Combine(currentFolder, archFolder, "CefSharp.BrowserSubprocess.exe"); + LibCefLoadStatus = (true, libCefPath, browserSubProcessPath, handle); + } + } + else + { + LibCefLoadStatus = (false, libCefPath, null, IntPtr.Zero); + } + } + //var assembly = LoadCefSharpCoreRuntime(); + + //NativeLibrary.SetDllImportResolver(typeof(CefSharp.Core.CefSettingsBase).Assembly, LibCefImportResolver); + + //CefSharpCoreRuntimeLocation = assembly.Location; + } + + //private static IntPtr LibCefImportResolver(string libraryName, Assembly assembly, DllImportSearchPath? searchPath) + //{ + // return IntPtr.Zero; + //} + + //public static Assembly LoadCefSharpCoreRuntime() + //{ + // //Load into the same context as CefSharp.Core, if user was to create their own context then + // //this should keep thing together. + // var currentCtx = AssemblyLoadContext.GetLoadContext(typeof(Initializer).Assembly); + + // var browserSubprocessDllPath = Path.Combine(Path.GetDirectoryName(typeof(Initializer).Assembly.Location), "CefSharp.Core.Runtime.dll"); + // return currentCtx.LoadFromAssemblyPath(browserSubprocessDllPath); + //} + } +} diff --git a/CefSharp.Core/ManagedCefBrowserAdapter.cpp b/CefSharp.Core/ManagedCefBrowserAdapter.cpp deleted file mode 100644 index 2e57b8802e..0000000000 --- a/CefSharp.Core/ManagedCefBrowserAdapter.cpp +++ /dev/null @@ -1,204 +0,0 @@ -// Copyright © 2014 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#include "Stdafx.h" - -#include "ManagedCefBrowserAdapter.h" -#include "WindowInfo.h" -#include "Internals\Messaging\Messages.h" -#include "Internals\CefFrameWrapper.h" -#include "Internals\CefBrowserWrapper.h" -#include "Internals\Serialization\Primitives.h" -#include "Internals\Serialization\JsObjectsSerialization.h" - -using namespace CefSharp::Internals::Serialization; -using namespace CefSharp::Internals::Messaging; - -using namespace CefSharp::Internals::Messaging; - -bool ManagedCefBrowserAdapter::IsDisposed::get() -{ - return _isDisposed; -} - -void ManagedCefBrowserAdapter::CreateBrowser(IWindowInfo^ windowInfo, BrowserSettings^ browserSettings, RequestContext^ requestContext, String^ address) -{ - auto cefWindowInfoWrapper = static_cast(windowInfo); - - CefString addressNative = StringUtils::ToNative(address); - - if (browserSettings == nullptr) - { - throw gcnew ArgumentNullException("browserSettings", "cannot be null"); - } - - if (browserSettings->IsDisposed) - { - throw gcnew ObjectDisposedException("browserSettings", "browser settings has already been disposed. " + - "BrowserSettings created by CefSharp are automatically disposed, to control the lifecycle create and set your own instance."); - } - - auto objectRepository = _javaScriptObjectRepository; - - //It's no longer possible to change these settings - objectRepository->Settings->Freeze(); - - CefRefPtr extraInfo = CefDictionaryValue::Create(); - auto legacyBindingEnabled = false; - - if (objectRepository->Settings->LegacyBindingEnabled) - { - auto legacyBoundObjects = objectRepository->GetLegacyBoundObjects(); - - legacyBindingEnabled = objectRepository->HasBoundObjects; - - //For legacy binding we only add values if we have bond objects. - if (legacyBindingEnabled) - { - auto listValue = CefListValue::Create(); - - SerializeJsObjects(legacyBoundObjects, listValue, 0); - - extraInfo->SetList("LegacyBindingObjects", listValue); - } - } - - extraInfo->SetBool("LegacyBindingEnabled", legacyBindingEnabled); - - if (!String::IsNullOrEmpty(objectRepository->Settings->JavascriptBindingApiGlobalObjectName)) - { - auto globalObjName = objectRepository->Settings->JavascriptBindingApiGlobalObjectName; - - if (StringCheck::IsFirstCharacterLowercase(globalObjName)) - { - extraInfo->SetString("JsBindingPropertyNameCamelCase", StringUtils::ToNative(globalObjName)); - } - else - { - extraInfo->SetString("JsBindingPropertyName", StringUtils::ToNative(globalObjName)); - } - } - - if (!CefBrowserHost::CreateBrowser(*cefWindowInfoWrapper->GetWindowInfo(), _clientAdapter.get(), addressNative, - *browserSettings->_browserSettings, extraInfo, static_cast>(requestContext))) - { - throw gcnew InvalidOperationException("CefBrowserHost::CreateBrowser call failed, review the CEF log file for more details."); - } - - delete windowInfo; -} - -#ifndef NETCOREAPP -// NOTE: This was moved out of OnAfterBrowserCreated to prevent the System.ServiceModel assembly from being loaded when WCF is not enabled. -__declspec(noinline) void ManagedCefBrowserAdapter::InitializeBrowserProcessServiceHost(IBrowser^ browser) -{ - _browserProcessServiceHost = gcnew BrowserProcessServiceHost(_javaScriptObjectRepository, Process::GetCurrentProcess()->Id, browser->Identifier, _javascriptCallbackFactory); - //NOTE: Attempt to solve timing issue where browser is opened and rapidly disposed. In some cases a call to Open throws - // an exception about the process already being closed. Two relevant issues are #862 and #804. - if (_browserProcessServiceHost->State == CommunicationState::Created) - { - try - { - _browserProcessServiceHost->Open(); - } - catch (Exception^) - { - //Ignore exception as it's likely cause when the browser is closing - } - } -} - -// NOTE: This was moved out of ~ManagedCefBrowserAdapter to prevent the System.ServiceModel assembly from being loaded when WCF is not enabled. -__declspec(noinline) void ManagedCefBrowserAdapter::DisposeBrowserProcessServiceHost() -{ - if (_browserProcessServiceHost != nullptr) - { - if (CefSharpSettings::WcfTimeout > TimeSpan::Zero) - { - _browserProcessServiceHost->Close(CefSharpSettings::WcfTimeout); - } - else - { - _browserProcessServiceHost->Abort(); - } - _browserProcessServiceHost = nullptr; - } -} -#endif - -void ManagedCefBrowserAdapter::OnAfterBrowserCreated(IBrowser^ browser) -{ - if (!_isDisposed) - { - _browserWrapper = browser; - _javascriptCallbackFactory->BrowserAdapter = gcnew WeakReference(this); - - //Browser has been initialized, it's now too late to register a sync JSB object if Wcf wasn't enabled - _javaScriptObjectRepository->IsBrowserInitialized = true; - -#ifndef NETCOREAPP - if (CefSharpSettings::WcfEnabled) - { - InitializeBrowserProcessServiceHost(browser); - } -#endif - - if (_webBrowserInternal != nullptr) - { - _webBrowserInternal->OnAfterBrowserCreated(browser); - } - } -} - -void ManagedCefBrowserAdapter::Resize(int width, int height) -{ - HWND browserHwnd = _clientAdapter->GetBrowserHwnd(); - if (browserHwnd) - { - if (width == 0 && height == 0) - { - // For windowed browsers when the frame window is minimized set the - // browser window size to 0x0 to reduce resource usage. - SetWindowPos(browserHwnd, NULL, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOMOVE | SWP_NOACTIVATE); - } - else - { - SetWindowPos(browserHwnd, NULL, 0, 0, width, height, SWP_NOZORDER); - } - } -} - -IBrowser^ ManagedCefBrowserAdapter::GetBrowser(int browserId) -{ - return _clientAdapter->GetBrowserWrapper(browserId); -} - -IJavascriptCallbackFactory^ ManagedCefBrowserAdapter::JavascriptCallbackFactory::get() -{ - return _javascriptCallbackFactory; -} - -IJavascriptObjectRepositoryInternal^ ManagedCefBrowserAdapter::JavascriptObjectRepository::get() -{ - return _javaScriptObjectRepository; -} - -IMethodRunnerQueue^ ManagedCefBrowserAdapter::MethodRunnerQueue::get() -{ - return _methodRunnerQueue; -} - -void ManagedCefBrowserAdapter::MethodInvocationComplete(Object^ sender, MethodInvocationCompleteArgs^ e) -{ - auto result = e->Result; - if (result->CallbackId.HasValue) - { - _clientAdapter->MethodInvocationComplete(result); - } -} - -MCefRefPtr ManagedCefBrowserAdapter::GetClientAdapter() -{ - return _clientAdapter; -} diff --git a/CefSharp.Core/ManagedCefBrowserAdapter.h b/CefSharp.Core/ManagedCefBrowserAdapter.h deleted file mode 100644 index e6bff64e23..0000000000 --- a/CefSharp.Core/ManagedCefBrowserAdapter.h +++ /dev/null @@ -1,152 +0,0 @@ -// Copyright © 2013 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#ifndef CEFSHARP_CORE_MANAGEDCEFBROWSERADAPTER_H_ -#define CEFSHARP_CORE_MANAGEDCEFBROWSERADAPTER_H_ - -#pragma once - -#include "Stdafx.h" - -#include "include\cef_client.h" - -#include "BrowserSettings.h" -#include "RequestContext.h" -#include "Internals/ClientAdapter.h" -#include "Internals/CefDragDataWrapper.h" -#include "Internals/RenderClientAdapter.h" -#include "Internals/JavascriptCallbackFactory.h" - -using namespace System::Diagnostics; -#ifndef NETCOREAPP -using namespace System::ServiceModel; -using namespace CefSharp::Internals::Wcf; -#endif -using namespace System::Threading; -using namespace System::Threading::Tasks; - -namespace CefSharp -{ - /// - public ref class ManagedCefBrowserAdapter : public IBrowserAdapter - { - MCefRefPtr _clientAdapter; -#ifndef NETCOREAPP - BrowserProcessServiceHost^ _browserProcessServiceHost; -#endif - IWebBrowserInternal^ _webBrowserInternal; - IJavascriptObjectRepositoryInternal^ _javaScriptObjectRepository; - JavascriptCallbackFactory^ _javascriptCallbackFactory; - IMethodRunnerQueue^ _methodRunnerQueue; - IBrowser^ _browserWrapper; - bool _isDisposed; - - private: - void MethodInvocationComplete(Object^ sender, MethodInvocationCompleteArgs^ e); -#ifndef NETCOREAPP - void InitializeBrowserProcessServiceHost(IBrowser^ browser); - void DisposeBrowserProcessServiceHost(); -#endif - - internal: - MCefRefPtr GetClientAdapter(); - - public: - ManagedCefBrowserAdapter(IWebBrowserInternal^ webBrowserInternal, bool offScreenRendering) - : _isDisposed(false) - { - if (offScreenRendering) - { - _clientAdapter = new RenderClientAdapter(webBrowserInternal, this); - } - else - { - _clientAdapter = new ClientAdapter(webBrowserInternal, this); - } - - _webBrowserInternal = webBrowserInternal; - _javaScriptObjectRepository = gcnew CefSharp::Internals::JavascriptObjectRepository(); - _javascriptCallbackFactory = gcnew CefSharp::Internals::JavascriptCallbackFactory(_clientAdapter->GetPendingTaskRepository()); - - if (CefSharpSettings::ConcurrentTaskExecution) - { - _methodRunnerQueue = gcnew CefSharp::Internals::ConcurrentMethodRunnerQueue(_javaScriptObjectRepository); - } - else - { - _methodRunnerQueue = gcnew CefSharp::Internals::MethodRunnerQueue(_javaScriptObjectRepository); - } - - _methodRunnerQueue->MethodInvocationComplete += gcnew EventHandler(this, &ManagedCefBrowserAdapter::MethodInvocationComplete); - } - - !ManagedCefBrowserAdapter() - { - _clientAdapter = nullptr; - } - - ~ManagedCefBrowserAdapter() - { - _isDisposed = true; - - // Stop the method runner before releasing browser adapter and browser wrapper (#2529) - if (_methodRunnerQueue != nullptr) - { - _methodRunnerQueue->MethodInvocationComplete -= gcnew EventHandler(this, &ManagedCefBrowserAdapter::MethodInvocationComplete); - delete _methodRunnerQueue; - _methodRunnerQueue = nullptr; - } - - // Release the MCefRefPtr reference - // before calling _browserWrapper->CloseBrowser(true) - this->!ManagedCefBrowserAdapter(); - - if (_browserWrapper != nullptr) - { - _browserWrapper->CloseBrowser(true); - - delete _browserWrapper; - _browserWrapper = nullptr; - } - -#ifndef NETCOREAPP - if (CefSharpSettings::WcfEnabled) - { - DisposeBrowserProcessServiceHost(); - } -#endif - - _webBrowserInternal = nullptr; - delete _javaScriptObjectRepository; - _javaScriptObjectRepository = nullptr; - } - - virtual property bool IsDisposed - { - bool get(); - } - - virtual void OnAfterBrowserCreated(IBrowser^ browser); - void CreateBrowser(IWindowInfo^ windowInfo, BrowserSettings^ browserSettings, RequestContext^ requestContext, String^ address); - virtual void Resize(int width, int height); - - virtual IBrowser^ GetBrowser(int browserId); - - virtual property IJavascriptCallbackFactory^ JavascriptCallbackFactory - { - CefSharp::Internals::IJavascriptCallbackFactory^ get(); - } - - virtual property IJavascriptObjectRepositoryInternal^ JavascriptObjectRepository - { - CefSharp::Internals::IJavascriptObjectRepositoryInternal^ get(); - } - - virtual property IMethodRunnerQueue^ MethodRunnerQueue - { - CefSharp::Internals::IMethodRunnerQueue^ get(); - } - }; -} -#endif // CEFSHARP_CORE_INTERNALS_CLIENTADAPTER_H_ diff --git a/CefSharp.Core/ModuleInitializerAttribute.cs b/CefSharp.Core/ModuleInitializerAttribute.cs new file mode 100644 index 0000000000..98f8bd4fca --- /dev/null +++ b/CefSharp.Core/ModuleInitializerAttribute.cs @@ -0,0 +1,7 @@ +namespace System.Runtime.CompilerServices +{ + [AttributeUsage(AttributeTargets.Method, AllowMultiple = false)] + public sealed class ModuleInitializerAttribute : Attribute + { + } +} diff --git a/CefSharp.Core/NativeMethodWrapper.cpp b/CefSharp.Core/NativeMethodWrapper.cpp deleted file mode 100644 index fc88312e12..0000000000 --- a/CefSharp.Core/NativeMethodWrapper.cpp +++ /dev/null @@ -1,61 +0,0 @@ -// Copyright © 2014 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#include "Stdafx.h" - -#include "NativeMethodWrapper.h" - -namespace CefSharp -{ - void NativeMethodWrapper::MemoryCopy(IntPtr dest, IntPtr src, int numberOfBytes) - { - RtlCopyMemory(dest.ToPointer(), src.ToPointer(), numberOfBytes); - } - - bool NativeMethodWrapper::IsFocused(IntPtr handle) - { - // Ask Windows which control has the focus and then check if it's one of our children - auto focusControl = GetFocus(); - return focusControl != 0 && (IsChild((HWND)handle.ToPointer(), focusControl) == 1); - } - - void NativeMethodWrapper::SetWindowPosition(IntPtr handle, int x, int y, int width, int height) - { - HWND browserHwnd = static_cast(handle.ToPointer()); - if (browserHwnd) - { - if (width == 0 && height == 0) - { - // For windowed browsers when the frame window is minimized set the - // browser window size to 0x0 to reduce resource usage. - SetWindowPos(browserHwnd, NULL, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOMOVE | SWP_NOACTIVATE); - } - else - { - SetWindowPos(browserHwnd, NULL, x, y, width, height, SWP_NOZORDER); - } - } - } - - void NativeMethodWrapper::SetWindowParent(IntPtr child, IntPtr newParent) - { - HWND childHwnd = static_cast(child.ToPointer()); - HWND newParentHwnd = static_cast(newParent.ToPointer()); - - SetParent(childHwnd, newParentHwnd); - } - - void NativeMethodWrapper::RemoveExNoActivateStyle(IntPtr browserHwnd) - { - HWND hwnd = static_cast(browserHwnd.ToPointer()); - - auto exStyle = GetWindowLongPtr(hwnd, GWL_EXSTYLE); - - if (exStyle & WS_EX_NOACTIVATE) - { - //Remove WS_EX_NOACTIVATE - SetWindowLongPtr(hwnd, GWL_EXSTYLE, exStyle & ~WS_EX_NOACTIVATE); - } - } -} diff --git a/CefSharp.Core/NativeMethodWrapper.h b/CefSharp.Core/NativeMethodWrapper.h deleted file mode 100644 index da6b12041b..0000000000 --- a/CefSharp.Core/NativeMethodWrapper.h +++ /dev/null @@ -1,24 +0,0 @@ -// Copyright © 2012 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" - -namespace CefSharp -{ - /// - public ref class NativeMethodWrapper sealed - { - public: - //Method cannot be called CopyMemory/RtlCopyMemroy as that's a macro name - //Length is currently int, update if required to handle larger data structures - //(int is plenty big enough for our current use case) - static void MemoryCopy(IntPtr dest, IntPtr src, int numberOfBytes); - static bool IsFocused(IntPtr handle); - static void SetWindowPosition(IntPtr handle, int x, int y, int width, int height); - static void SetWindowParent(IntPtr child, IntPtr newParent); - static void RemoveExNoActivateStyle(IntPtr browserHwnd); - }; -} diff --git a/CefSharp.Core/PopupFeatures.h b/CefSharp.Core/PopupFeatures.h deleted file mode 100644 index 9f08f88426..0000000000 --- a/CefSharp.Core/PopupFeatures.h +++ /dev/null @@ -1,81 +0,0 @@ -// Copyright © 2016 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" - -namespace CefSharp -{ - /// - /// Class representing popup window features. - /// - /// - public ref class PopupFeatures : IPopupFeatures - { - private: - const CefPopupFeatures* _popupFeatures; - - internal: - /// - /// Constructor. - /// - /// The popup features. - PopupFeatures(const CefPopupFeatures* popupFeatures) - { - _popupFeatures = popupFeatures; - } - - public: - !PopupFeatures() - { - _popupFeatures = NULL; - } - - ~PopupFeatures() - { - this->!PopupFeatures(); - } - - virtual property System::Nullable X - { - System::Nullable get() { return _popupFeatures->xSet ? _popupFeatures->x : Nullable(); } - } - - virtual property System::Nullable Y - { - System::Nullable get() { return _popupFeatures->ySet ? _popupFeatures->y : Nullable(); } - } - - virtual property System::Nullable Width - { - System::Nullable get() { return _popupFeatures->widthSet ? _popupFeatures->width : Nullable(); } - } - - virtual property System::Nullable Height - { - System::Nullable get() { return _popupFeatures->heightSet ? _popupFeatures->height : Nullable(); } - } - - virtual property bool MenuBarVisible - { - bool get() { return _popupFeatures->menuBarVisible == 1; } - } - - virtual property bool StatusBarVisible - { - bool get() { return _popupFeatures->statusBarVisible == 1; } - } - - virtual property bool ToolBarVisible - { - bool get() { return _popupFeatures->toolBarVisible == 1; } - } - - virtual property bool ScrollbarsVisible - { - bool get() { return _popupFeatures->scrollbarsVisible == 1; } - } - }; -} diff --git a/CefSharp.Core/PostData.h b/CefSharp.Core/PostData.h deleted file mode 100644 index 9ef820e3fb..0000000000 --- a/CefSharp.Core/PostData.h +++ /dev/null @@ -1,234 +0,0 @@ -// Copyright © 2015 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" - -#include "include\cef_request.h" - -#include "PostDataElement.h" -#include "Internals\TypeConversion.h" -#include "Internals\CefWrapper.h" - -using namespace System::Collections::Generic; -using namespace System::Collections::ObjectModel; - -namespace CefSharp -{ - /// - /// Form Post Data - /// - /// - public ref class PostData : public IPostData, public CefWrapper - { - MCefRefPtr _postData; - List^ _postDataElements; - - internal: - PostData(CefRefPtr &postData) : - _postData(postData) - { - - } - - /// - /// Finalizer. - /// - !PostData() - { - _postData = nullptr; - } - - /// - /// Destructor. - /// - ~PostData() - { - this->!PostData(); - - if (_postDataElements != nullptr) - { - //Make sure the unmanaged resources are handled - for each (IPostDataElement^ element in _postDataElements) - { - delete element; - } - - _postDataElements = nullptr; - } - - _disposed = true; - } - - /// - /// Throw exception if Readonly - /// - /// Thrown when an exception error condition occurs. - void ThrowIfReadOnly() - { - if (IsReadOnly) - { - throw gcnew Exception(gcnew String(L"This IPostDataWrapper is readonly and cannot be modified.")); - } - } - - operator CefRefPtr() - { - if (this == nullptr) - { - return NULL; - } - return _postData.get(); - } - - public: - /// - /// Default constructor. - /// - PostData() - { - _postData = CefPostData::Create(); - } - - /// - /// Returns true if this object is read-only. - /// - virtual property bool IsReadOnly - { - bool get() - { - ThrowIfDisposed(); - - return _postData->IsReadOnly(); - } - } - - /// - /// Retrieve the post data elements. - /// - virtual property IList^ Elements - { - IList^ get() - { - ThrowIfDisposed(); - - if (_postDataElements == nullptr) - { - _postDataElements = gcnew List(); - - auto elementCount = _postData.get() ? _postData->GetElementCount() : 0; - if (elementCount == 0) - { - return gcnew ReadOnlyCollection(_postDataElements); - } - CefPostData::ElementVector ev; - - _postData->GetElements(ev); - - for (CefPostData::ElementVector::iterator it = ev.begin(); it != ev.end(); ++it) - { - CefPostDataElement *el = it->get(); - - _postDataElements->Add(gcnew PostDataElement(el)); - } - } - - return gcnew ReadOnlyCollection(_postDataElements); - } - } - - /// - /// Add the specified . - /// - /// element to be added. - /// Returns true if the add succeeds. - virtual bool AddElement(IPostDataElement^ element) - { - ThrowIfDisposed(); - - ThrowIfReadOnly(); - - //Access the Elements collection to initialize the underlying _postDataElements collection - auto elements = Elements; - - //If the element has already been added then don't add it again - if (elements->Contains(element)) - { - return false; - } - - _postDataElements->Add(element); - - auto elementWrapper = (PostDataElement^)element; - - return _postData->AddElement(elementWrapper); - } - - /// - /// Remove the specified . - /// - /// element to be removed. - /// Returns true if the add succeeds. - virtual bool RemoveElement(IPostDataElement^ element) - { - ThrowIfDisposed(); - - ThrowIfReadOnly(); - - //Access the Elements collection to initialize the underlying _postDataElements collection - auto elements = Elements; - - if (!elements->Contains(element)) - { - return false; - } - - _postDataElements->Remove(element); - - auto elementWrapper = (PostDataElement^)element; - - return _postData->RemoveElement(elementWrapper); - } - - /// - /// Remove all existing post data elements. - /// - virtual void RemoveElements() - { - ThrowIfDisposed(); - - ThrowIfReadOnly(); - - _postData->RemoveElements(); - } - - /// - /// Create a new instance - /// - /// PostDataElement - virtual IPostDataElement^ CreatePostDataElement() - { - auto element = CefPostDataElement::Create(); - - return gcnew PostDataElement(element); - } - - /// - /// Returns true if the underlying POST data includes elements that are not - /// represented by this IPostData object (for example, multi-part file upload - /// data). Modifying IPostData objects with excluded elements may result in - /// the request failing. - /// - virtual property bool HasExcludedElements - { - bool get() - { - ThrowIfDisposed(); - - return _postData->HasExcludedElements(); - } - } - }; -} diff --git a/CefSharp.Core/PostDataElement.h b/CefSharp.Core/PostDataElement.h deleted file mode 100644 index 696f27309a..0000000000 --- a/CefSharp.Core/PostDataElement.h +++ /dev/null @@ -1,125 +0,0 @@ -// Copyright © 2015 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" - -#include "include\cef_request.h" -#include "Internals\TypeConversion.h" -#include "Internals\CefWrapper.h" - -using namespace System::Collections::Specialized; - -namespace CefSharp -{ - public ref class PostDataElement : public IPostDataElement, public CefWrapper - { - MCefRefPtr _postDataElement; - internal: - PostDataElement(CefRefPtr postDataElement) : - _postDataElement(postDataElement) - { - - } - - !PostDataElement() - { - _postDataElement = nullptr; - } - - ~PostDataElement() - { - this->!PostDataElement(); - - _disposed = true; - } - - operator CefRefPtr() - { - if (this == nullptr) - { - return NULL; - } - return _postDataElement.get(); - } - - public: - PostDataElement() - { - _postDataElement = CefPostDataElement::Create(); - } - - virtual property bool IsReadOnly - { - bool get() - { - ThrowIfDisposed(); - - return _postDataElement->IsReadOnly(); - } - } - - virtual property String^ File - { - String^ get() - { - ThrowIfDisposed(); - - return StringUtils::ToClr(_postDataElement->GetFile()); - } - void set(String^ val) - { - ThrowIfDisposed(); - - _postDataElement->SetToFile(StringUtils::ToNative(val)); - } - } - - virtual void SetToEmpty() - { - ThrowIfDisposed(); - - _postDataElement->SetToEmpty(); - } - - virtual property PostDataElementType Type - { - PostDataElementType get() - { - ThrowIfDisposed(); - - return (PostDataElementType)_postDataElement->GetType(); - } - } - - virtual property cli::array^ Bytes - { - cli::array^ get() - { - ThrowIfDisposed(); - - auto byteCount = _postDataElement->GetBytesCount(); - if (byteCount == 0) - { - return nullptr; - } - - auto bytes = gcnew cli::array(byteCount); - pin_ptr src = &bytes[0]; // pin pointer to first element in arr - - _postDataElement->GetBytes(byteCount, static_cast(src)); - - return bytes; - } - void set(cli::array^ val) - { - ThrowIfDisposed(); - - pin_ptr src = &val[0]; - _postDataElement->SetToBytes(val->Length, static_cast(src)); - } - } - }; -} diff --git a/CefSharp.Core.RefAssembly/Properties/AssemblyInfo.cs b/CefSharp.Core/Properties/AssemblyInfo.cs similarity index 90% rename from CefSharp.Core.RefAssembly/Properties/AssemblyInfo.cs rename to CefSharp.Core/Properties/AssemblyInfo.cs index 5c33df57cf..004e672505 100644 --- a/CefSharp.Core.RefAssembly/Properties/AssemblyInfo.cs +++ b/CefSharp.Core/Properties/AssemblyInfo.cs @@ -4,7 +4,7 @@ using CefSharp; [assembly:AssemblyTitle("CefSharp.Core")] -[assembly:AssemblyDescription("CefSharp Core Library (VC++)")] +[assembly:AssemblyDescription("CefSharp Core Library")] [assembly:AssemblyCompany(AssemblyInfo.AssemblyCompany)] [assembly:AssemblyProduct(AssemblyInfo.AssemblyProduct)] [assembly:AssemblyCopyright(AssemblyInfo.AssemblyCopyright)] diff --git a/CefSharp.Core/PublicApi.cs b/CefSharp.Core/PublicApi.cs new file mode 100644 index 0000000000..41ca4bb771 --- /dev/null +++ b/CefSharp.Core/PublicApi.cs @@ -0,0 +1,1504 @@ +// Copyright © 2020 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +//NOTE:Classes in the CefSharp.Core namespace have been hidden from intellisnse so users don't use them directly + +using System; +using System.Collections.Generic; +using System.IO; +using System.Threading.Tasks; +using CefSharp.Handler; +using CefSharp.Internals; + +namespace CefSharp.BrowserSubprocess +{ + public class SelfHost + { + /// + /// This function should be called from the application entry point function (typically Program.Main) + /// to execute a secondary process e.g. gpu, plugin, renderer, utility + /// This overload is specifically used for .Net Core. For hosting your own BrowserSubProcess + /// it's preferable to use the Main method provided by this class. + /// - Pass in command line args + /// - To support High DPI Displays you should call Cef.EnableHighDPISupport before any other processing + /// or add the relevant entries to your app.manifest + /// + /// command line args + /// + /// If called for the browser process (identified by no "type" command-line value) it will return immediately + /// with a value of -1. If called for a recognized secondary process it will block until the process should exit + /// and then return the process exit code. + /// + public static int Main(string[] args) + { + var type = CommandLineArgsParser.GetArgumentValue(args, CefSharpArguments.SubProcessTypeArgument); + + if (string.IsNullOrEmpty(type)) + { + //If --type param missing from command line CEF/Chromium assums + //this is the main process (as all subprocesses must have a type param). + //Return -1 to indicate this behaviour. + return -1; + } + + var browserSubprocessDllPath = Path.Combine(Path.GetDirectoryName(typeof(CefSharp.Core.BrowserSettings).Assembly.Location), "CefSharp.BrowserSubprocess.Core.dll"); +#if NETCOREAPP + var browserSubprocessDll = System.Runtime.Loader.AssemblyLoadContext.Default.LoadFromAssemblyPath(browserSubprocessDllPath); +#else + var browserSubprocessDll = System.Reflection.Assembly.LoadFrom(browserSubprocessDllPath); +#endif + var browserSubprocessExecutableType = browserSubprocessDll.GetType("CefSharp.BrowserSubprocess.BrowserSubprocessExecutable"); + var browserSubprocessExecutable = Activator.CreateInstance(browserSubprocessExecutableType); + + var mainMethod = browserSubprocessExecutableType.GetMethod("MainSelfHost", System.Reflection.BindingFlags.Static | System.Reflection.BindingFlags.Public); + var argCount = mainMethod.GetParameters(); + + var methodArgs = new object[] {args } ; + + var exitCode = mainMethod.Invoke(null, methodArgs); + + return (int)exitCode; + } + } +} + +namespace CefSharp.Core +{ + public static class ObjectFactory + { + public static IBrowserSettings CreateBrowserSettings(bool autoDispose) + { + return new CefSharp.Core.BrowserSettings(autoDispose); + } + + public static IWindowInfo CreateWindowInfo() + { + return new CefSharp.Core.WindowInfo(); + } + } +} + +//TODO: Split out into seperate classes +namespace CefSharp +{ + /// + public class BrowserSettings : CefSharp.Core.BrowserSettings + { + /// + public BrowserSettings(bool autoDispose = false) : base(autoDispose) + { + + } + } + + /// + public static class Cef + { + public static TaskFactory UIThreadTaskFactory + { + get { return Core.Cef.UIThreadTaskFactory; } + } + public static TaskFactory IOThreadTaskFactory + { + get { return Core.Cef.IOThreadTaskFactory; } + } + public static TaskFactory FileThreadTaskFactory + { + get { return Core.Cef.FileThreadTaskFactory; } + } + + public static void AddDisposable(IDisposable item) + { + Core.Cef.AddDisposable(item); + } + + public static void RemoveDisposable(IDisposable item) + { + Core.Cef.RemoveDisposable(item); + } + + /// Gets a value that indicates whether CefSharp is initialized. + /// true if CefSharp is initialized; otherwise, false. + public static bool IsInitialized + { + get { return Core.Cef.IsInitialized; } + } + + /// Gets a value that indicates the version of CefSharp currently being used. + /// The CefSharp version. + public static string CefSharpVersion + { + get { return Core.Cef.CefSharpVersion; } + } + + /// Gets a value that indicates the CEF version currently being used. + /// The CEF Version + public static string CefVersion + { + get { return Core.Cef.CefVersion; } + } + + /// Gets a value that indicates the Chromium version currently being used. + /// The Chromium version. + public static string ChromiumVersion + { + get { return Core.Cef.ChromiumVersion; } + } + + /// + /// Gets a value that indicates the Git Hash for CEF version currently being used. + /// + /// The Git Commit Hash + public static string CefCommitHash + { + get { return Core.Cef.CefCommitHash; } + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize and Shutdown MUST be called on your main + /// application thread (typically the UI thread). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// true if successful; otherwise, false. + public static bool Initialize(CefSettingsBase cefSettings) + { + return Core.Cef.Initialize((CefSharp.Core.CefSettingsBase)cefSettings); + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize/Shutdown MUST be called on your main + /// application thread (typically the UI thread). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// Check that all relevant dependencies available, throws exception if any are missing + /// true if successful; otherwise, false. + public static bool Initialize(CefSettingsBase cefSettings, bool performDependencyCheck) + { + return Core.Cef.Initialize((CefSharp.Core.CefSettingsBase)cefSettings, performDependencyCheck); + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize/Shutdown MUST be called on your main + /// application thread (typically the UI thread). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// Check that all relevant dependencies available, throws exception if any are missing + /// The handler for functionality specific to the browser process. Null if you don't wish to handle these events + /// true if successful; otherwise, false. + public static bool Initialize(CefSettingsBase cefSettings, bool performDependencyCheck, IBrowserProcessHandler browserProcessHandler) + { + return Core.Cef.Initialize((CefSharp.Core.CefSettingsBase)cefSettings, performDependencyCheck, browserProcessHandler); + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize/Shutdown MUST be called on your main + /// application thread (typically the UI thread). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// Check that all relevant dependencies available, throws exception if any are missing + /// Implement this interface to provide handler implementations. Null if you don't wish to handle these events + /// true if successful; otherwise, false. + public static bool Initialize(CefSettingsBase cefSettings, bool performDependencyCheck, IApp cefApp) + { + return Core.Cef.Initialize((CefSharp.Core.CefSettingsBase)cefSettings, performDependencyCheck, cefApp); + } + + /// + /// Run the CEF message loop. Use this function instead of an application- + /// provided message loop to get the best balance between performance and CPU + /// usage. This function should only be called on the main application thread and + /// only if Cef.Initialize() is called with a + /// CefSettings.MultiThreadedMessageLoop value of false. This function will + /// block until a quit message is received by the system. + /// + public static void RunMessageLoop() + { + Core.Cef.RunMessageLoop(); + } + + /// + /// Quit the CEF message loop that was started by calling Cef.RunMessageLoop(). + /// This function should only be called on the main application thread and only + /// if Cef.RunMessageLoop() was used. + /// + public static void QuitMessageLoop() + { + Core.Cef.QuitMessageLoop(); + } + + /// + /// Perform a single iteration of CEF message loop processing.This function is + /// provided for cases where the CEF message loop must be integrated into an + /// existing application message loop. Use of this function is not recommended + /// for most users; use CefSettings.MultiThreadedMessageLoop if possible (the default). + /// When using this function care must be taken to balance performance + /// against excessive CPU usage. It is recommended to enable the + /// CefSettings.ExternalMessagePump option when using + /// this function so that IBrowserProcessHandler.OnScheduleMessagePumpWork() + /// callbacks can facilitate the scheduling process. This function should only be + /// called on the main application thread and only if Cef.Initialize() is called + /// with a CefSettings.MultiThreadedMessageLoop value of false. This function + /// will not block. + /// + public static void DoMessageLoopWork() + { + Core.Cef.DoMessageLoopWork(); + } + + /// + /// This function should be called from the application entry point function to execute a secondary process. + /// It can be used to run secondary processes from the browser client executable (default behavior) or + /// from a separate executable specified by the CefSettings.browser_subprocess_path value. + /// If called for the browser process (identified by no "type" command-line value) it will return immediately with a value of -1. + /// If called for a recognized secondary process it will block until the process should exit and then return the process exit code. + /// The |application| parameter may be empty. The |windows_sandbox_info| parameter is only used on Windows and may be NULL (see cef_sandbox_win.h for details). + /// + public static int ExecuteProcess() + { + return Core.Cef.ExecuteProcess(); + } + + /// Add an entry to the cross-origin whitelist. + /// The origin allowed to be accessed by the target protocol/domain. + /// The target protocol allowed to access the source origin. + /// The optional target domain allowed to access the source origin. + /// If set to true would allow a blah.example.com if the + /// was set to example.com + /// + /// Returns false if is invalid or the whitelist cannot be accessed. + /// + /// The same-origin policy restricts how scripts hosted from different origins + /// (scheme + domain + port) can communicate. By default, scripts can only access + /// resources with the same origin. Scripts hosted on the HTTP and HTTPS schemes + /// (but no other schemes) can use the "Access-Control-Allow-Origin" header to + /// allow cross-origin requests. For example, https://source.example.com can make + /// XMLHttpRequest requests on http://target.example.com if the + /// http://target.example.com request returns an "Access-Control-Allow-Origin: + /// https://source.example.com" response header. + /// + /// Scripts in separate frames or iframes and hosted from the same protocol and + /// domain suffix can execute cross-origin JavaScript if both pages set the + /// document.domain value to the same domain suffix. For example, + /// scheme://foo.example.com and scheme://bar.example.com can communicate using + /// JavaScript if both domains set document.domain="example.com". + /// + /// This method is used to allow access to origins that would otherwise violate + /// the same-origin policy. Scripts hosted underneath the fully qualified + /// URL (like http://www.example.com) will be allowed access to + /// all resources hosted on the specified and . + /// If is non-empty and if false only + /// exact domain matches will be allowed. If contains a top- + /// level domain component (like "example.com") and is + /// true sub-domain matches will be allowed. If is empty and + /// if true all domains and IP addresses will be + /// allowed. + /// + /// This method cannot be used to bypass the restrictions on local or display + /// isolated schemes. See the comments on for more + /// information. + /// + /// This function may be called on any thread. Returns false if + /// is invalid or the whitelist cannot be accessed. + /// + public static bool AddCrossOriginWhitelistEntry( + string sourceOrigin, + string targetProtocol, + string targetDomain, + bool allowTargetSubdomains) + { + return Core.Cef.AddCrossOriginWhitelistEntry( + sourceOrigin, + targetProtocol, + targetDomain, + allowTargetSubdomains); + } + + /// Remove entry from cross-origin whitelist + /// The origin allowed to be accessed by the target protocol/domain. + /// The target protocol allowed to access the source origin. + /// The optional target domain allowed to access the source origin. + /// If set to true would allow a blah.example.com if the + /// was set to example.com + /// + /// + /// Remove an entry from the cross-origin access whitelist. Returns false if + /// is invalid or the whitelist cannot be accessed. + /// + public static bool RemoveCrossOriginWhitelistEntry(string sourceOrigin, + string targetProtocol, + string targetDomain, + bool allowTargetSubdomains) + + { + return Core.Cef.RemoveCrossOriginWhitelistEntry( + sourceOrigin, + targetProtocol, + targetDomain, + allowTargetSubdomains); + } + + /// Remove all entries from the cross-origin access whitelist. + /// + /// Remove all entries from the cross-origin access whitelist. Returns false if + /// the whitelist cannot be accessed. + /// + public static bool ClearCrossOriginWhitelist() + { + return Core.Cef.ClearCrossOriginWhitelist(); + } + + /// + /// Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. + /// Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() + /// The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, + /// there may be a short delay before you can Get/Write cookies. + /// To be sure the cookie manager has been initialized use one of the following + /// - Access the ICookieManager after ICompletionCallback.OnComplete has been called + /// - Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. + /// - Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + /// + /// If non-NULL it will be executed asynchronously on the CEF UI thread after the manager's storage has been initialized. + /// A the global cookie manager or null if the RequestContext has not yet been initialized. + public static ICookieManager GetGlobalCookieManager(ICompletionCallback callback = null) + { + + + return Core.Cef.GetGlobalCookieManager(callback); + } + + /// + /// Called prior to calling Cef.Shutdown, this disposes of any remaining + /// ChromiumWebBrowser instances. In WPF this is used from Dispatcher.ShutdownStarted + /// to release the unmanaged resources held by the ChromiumWebBrowser instances. + /// Generally speaking you don't need to call this yourself. + /// + public static void PreShutdown() + { + Core.Cef.PreShutdown(); + } + + /// + /// Shuts down CefSharp and the underlying CEF infrastructure. This method is safe to call multiple times; it will only + /// shut down CEF on the first call (all subsequent calls will be ignored). + /// This method should be called on the main application thread to shut down the CEF browser process before the application exits. + /// If you are Using CefSharp.OffScreen then you must call this explicitly before your application exits or it will hang. + /// This method must be called on the same thread as Initialize. If you don't call Shutdown explicitly then CefSharp.Wpf and CefSharp.WinForms + /// versions will do their best to call Shutdown for you, if your application is having trouble closing then call thus explicitly. + /// + public static void Shutdown() + { + Core.Cef.Shutdown(); + } + + /// + /// This method should only be used by advanced users, if you're unsure then use Cef.Shutdown(). + /// This function should be called on the main application thread to shut down + /// the CEF browser process before the application exits. This method simply obtains a lock + /// and calls the native CefShutdown method, only IsInitialized is checked. All ChromiumWebBrowser + /// instances MUST be Disposed of before calling this method. If calling this method results in a crash + /// or hangs then you're likely hanging on to some unmanaged resources or haven't closed all of your browser + /// instances + /// + public static void ShutdownWithoutChecks() + { + Core.Cef.ShutdownWithoutChecks(); + } + + /// + /// Clear all scheme handler factories registered with the global request context. + /// Returns false on error. This function may be called on any thread in the browser process. + /// Using this function is equivalent to calling Cef.GetGlobalRequestContext().ClearSchemeHandlerFactories(). + /// + /// Returns false on error. + public static bool ClearSchemeHandlerFactories() + { + return Core.Cef.ClearSchemeHandlerFactories(); + } + + /// + /// Visit web plugin information. Can be called on any thread in the browser process. + /// + public static void VisitWebPluginInfo(IWebPluginInfoVisitor visitor) + { + Core.Cef.VisitWebPluginInfo(visitor); + } + + /// + /// Async returns a list containing Plugin Information + /// (Wrapper around CefVisitWebPluginInfo) + /// + /// Returns List of structs. + public static Task> GetPlugins() + { + return Core.Cef.GetPlugins(); + } + + /// + /// Cause the plugin list to refresh the next time it is accessed regardless of whether it has already been loaded. + /// + public static void RefreshWebPlugins() + { + Core.Cef.RefreshWebPlugins(); + } + + /// + /// Unregister an internal plugin. This may be undone the next time RefreshWebPlugins() is called. + /// + /// Path (directory + file). + public static void UnregisterInternalWebPlugin(string path) + { + Core.Cef.UnregisterInternalWebPlugin(path); + } + + /// + /// Call during process startup to enable High-DPI support on Windows 7 or newer. + /// Older versions of Windows should be left DPI-unaware because they do not + /// support DirectWrite and GDI fonts are kerned very badly. + /// + public static void EnableHighDPISupport() + { + Core.Cef.EnableHighDPISupport(); + } + + /// + /// Returns true if called on the specified CEF thread. + /// + /// Returns true if called on the specified thread. + public static bool CurrentlyOnThread(CefThreadIds threadId) + { + return Core.Cef.CurrentlyOnThread(threadId); + } + + /// + /// Gets the Global Request Context. Make sure to Dispose of this object when finished. + /// The earlier possible place to access the IRequestContext is in IBrowserProcessHandler.OnContextInitialized. + /// Alternative use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + /// + /// Returns the global request context or null if the RequestContext has not been initialized yet. + public static IRequestContext GetGlobalRequestContext() + { + return Core.Cef.GetGlobalRequestContext(); + } + + /// + /// Helper function (wrapper around the CefColorSetARGB macro) which combines + /// the 4 color components into an uint32 for use with BackgroundColor property + /// + /// Alpha + /// Red + /// Green + /// Blue + /// Returns the color. + public static UInt32 ColorSetARGB(UInt32 a, UInt32 r, UInt32 g, UInt32 b) + { + return Core.Cef.ColorSetARGB(a, r, g, b); + } + + /// + /// Crash reporting is configured using an INI-style config file named + /// crash_reporter.cfg. This file must be placed next to + /// the main application executable. File contents are as follows: + /// + /// # Comments start with a hash character and must be on their own line. + /// + /// [Config] + /// ProductName=<Value of the "prod" crash key; defaults to "cef"> + /// ProductVersion=<Value of the "ver" crash key; defaults to the CEF version> + /// AppName=<Windows only; App-specific folder name component for storing crash + /// information; default to "CEF"> + /// ExternalHandler=<Windows only; Name of the external handler exe to use + /// instead of re-launching the main exe; default to empty> + /// ServerURL=<crash server URL; default to empty> + /// RateLimitEnabled=<True if uploads should be rate limited; default to true> + /// MaxUploadsPerDay=<Max uploads per 24 hours, used if rate limit is enabled; + /// default to 5> + /// MaxDatabaseSizeInMb=<Total crash report disk usage greater than this value + /// will cause older reports to be deleted; default to 20> + /// MaxDatabaseAgeInDays=<Crash reports older than this value will be deleted; + /// default to 5> + /// + /// [CrashKeys] + /// my_key1=<small|medium|large> + /// my_key2=<small|medium|large> + /// + /// Config section: + /// + /// If "ProductName" and/or "ProductVersion" are set then the specified values + /// will be included in the crash dump metadata. + /// + /// If "AppName" is set on Windows then crash report information (metrics, + /// database and dumps) will be stored locally on disk under the + /// "C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. + /// + /// If "ExternalHandler" is set on Windows then the specified exe will be + /// launched as the crashpad-handler instead of re-launching the main process + /// exe. The value can be an absolute path or a path relative to the main exe + /// directory. + /// + /// If "ServerURL" is set then crashes will be uploaded as a multi-part POST + /// request to the specified URL. Otherwise, reports will only be stored locally + /// on disk. + /// + /// If "RateLimitEnabled" is set to true then crash report uploads will be rate + /// limited as follows: + /// 1. If "MaxUploadsPerDay" is set to a positive value then at most the + /// specified number of crashes will be uploaded in each 24 hour period. + /// 2. If crash upload fails due to a network or server error then an + /// incremental backoff delay up to a maximum of 24 hours will be applied for + /// retries. + /// 3. If a backoff delay is applied and "MaxUploadsPerDay" is > 1 then the + /// "MaxUploadsPerDay" value will be reduced to 1 until the client is + /// restarted. This helps to avoid an upload flood when the network or + /// server error is resolved. + /// + /// If "MaxDatabaseSizeInMb" is set to a positive value then crash report storage + /// on disk will be limited to that size in megabytes. For example, on Windows + /// each dump is about 600KB so a "MaxDatabaseSizeInMb" value of 20 equates to + /// about 34 crash reports stored on disk. + /// + /// If "MaxDatabaseAgeInDays" is set to a positive value then crash reports older + /// than the specified age in days will be deleted. + /// + /// CrashKeys section: + /// + /// Any number of crash keys can be specified for use by the application. Crash + /// key values will be truncated based on the specified size (small = 63 bytes, + /// medium = 252 bytes, large = 1008 bytes). The value of crash keys can be set + /// from any thread or process using the Cef.SetCrashKeyValue function. These + /// key/value pairs will be sent to the crash server along with the crash dump + /// file. Medium and large values will be chunked for submission. For example, + /// if your key is named "mykey" then the value will be broken into ordered + /// chunks and submitted using keys named "mykey-1", "mykey-2", etc. + /// + /// Returns true if crash reporting is enabled. + public static bool CrashReportingEnabled + { + get { return Core.Cef.CrashReportingEnabled; } + } + + /// + /// Sets or clears a specific key-value pair from the crash metadata. + /// + public static void SetCrashKeyValue(string c, string value) + { + Core.Cef.SetCrashKeyValue(value, value); + } + + /// + /// Register the Widevine CDM plugin. + /// + /// The client application is responsible for downloading an appropriate + /// platform-specific CDM binary distribution from Google, extracting the + /// contents, and building the required directory structure on the local machine. + /// The method class can be used + /// to implement this functionality in CefSharp. Contact Google via + /// https://www.widevine.com/contact.html for details on CDM download. + /// + /// + /// path is a directory that must contain the following files: + /// 1. manifest.json file from the CDM binary distribution (see below). + /// 2. widevinecdm file from the CDM binary distribution (e.g. + /// widevinecdm.dll on Windows). + /// 3. widevidecdmadapter file from the CEF binary distribution (e.g. + /// widevinecdmadapter.dll on Windows). + /// + /// If any of these files are missing or if the manifest file has incorrect + /// contents the registration will fail and callback will receive an ErrorCode + /// value of . + /// + /// The manifest.json file must contain the following keys: + /// A. "os": Supported OS (e.g. "mac", "win" or "linux"). + /// B. "arch": Supported architecture (e.g. "ia32" or "x64"). + /// C. "x-cdm-module-versions": Module API version (e.g. "4"). + /// D. "x-cdm-interface-versions": Interface API version (e.g. "8"). + /// E. "x-cdm-host-versions": Host API version (e.g. "8"). + /// F. "version": CDM version (e.g. "1.4.8.903"). + /// G. "x-cdm-codecs": List of supported codecs (e.g. "vp8,vp9.0,avc1"). + /// + /// A through E are used to verify compatibility with the current Chromium + /// version. If the CDM is not compatible the registration will fail and + /// callback will receive an ErrorCode value of . + /// + /// If registration is not supported at the time that Cef.RegisterWidevineCdm() is called then callback + /// will receive an ErrorCode value of . + /// + /// is a directory that contains the Widevine CDM files + /// optional callback - + /// will be executed asynchronously once registration is complete + public static void RegisterWidevineCdm(string path, IRegisterCdmCallback callback = null) + { + Core.Cef.RegisterWidevineCdm(path, callback); + } + + /// + /// Register the Widevine CDM plugin. + /// + /// See for more details. + /// + /// is a directory that contains the Widevine CDM files + /// Returns a Task that can be awaited to receive the response. + public static Task RegisterWidevineCdmAsync(string path) + { + return Core.Cef.RegisterWidevineCdmAsync(path); + } + + /// + /// Returns the mime type for the specified file extension or an empty string if unknown. + /// + /// file extension + /// Returns the mime type for the specified file extension or an empty string if unknown. + public static string GetMimeType(string extension) + { + return Core.Cef.GetMimeType(extension); + } + + /// + /// WaitForBrowsersToClose is not enabled by default, call this method + /// before Cef.Initialize to enable. If you aren't calling Cef.Initialize + /// explicitly then this should be called before creating your first + /// ChromiumWebBrowser instance. + /// + public static void EnableWaitForBrowsersToClose() + { + Core.Cef.EnableWaitForBrowsersToClose(); + } + + /// + /// Helper method to ensure all ChromiumWebBrowser instances have been + /// closed/disposed, should be called before Cef.Shutdown. + /// Disposes all remaining ChromiumWebBrowser instances + /// then waits for CEF to release its remaining CefBrowser instances. + /// Finally a small delay of 50ms to allow for CEF to finish it's cleanup. + /// Should only be called when MultiThreadedMessageLoop = true; + /// (Hasn't been tested when when CEF integrates into main message loop). + /// + public static void WaitForBrowsersToClose() + { + Core.Cef.WaitForBrowsersToClose(); + } + } + + /// + public abstract class CefSettingsBase + { + internal Core.CefSettingsBase settings = new Core.CefSettingsBase(); + +#if NETCOREAPP + public CefSettingsBase() : base() + { + if(!File.Exists(BrowserSubprocessPath)) + { + var libCefLoadStatus = Initializer.LibCefLoadStatus; + if(libCefLoadStatus.Loaded) + { + BrowserSubprocessPath = libCefLoadStatus.BrowserSubProcessPath; + } + } + } +#endif + + public static explicit operator CefSharp.Core.CefSettingsBase(CefSettingsBase s) + { + return s.settings; + } + + /// + /// Add Customs schemes to this collection. + /// + public IEnumerable CefCustomSchemes + { + get { return settings.CefCustomSchemes; } + } + + /// + /// Add custom command line argumens to this collection, they will be added in OnBeforeCommandLineProcessing. The + /// CefSettings.CommandLineArgsDisabled value can be used to start with an empty command-line object. Any values specified in + /// CefSettings that equate to command-line arguments will be set before this method is called. + /// + public CommandLineArgDictionary CefCommandLineArgs + { + get { return settings.CefCommandLineArgs; } + } + + /// + /// Set to true to disable configuration of browser process features using standard CEF and Chromium command-line arguments. + /// Configuration can still be specified using CEF data structures or by adding to CefCommandLineArgs. + /// + public bool CommandLineArgsDisabled + { + get { return settings.CommandLineArgsDisabled; } + set { settings.CommandLineArgsDisabled = value; } + } + + /// + /// Set to true to control browser process main (UI) thread message pump scheduling via the + /// IBrowserProcessHandler.OnScheduleMessagePumpWork callback. This option is recommended for use in combination with the + /// Cef.DoMessageLoopWork() function in cases where the CEF message loop must be integrated into an existing application message + /// loop (see additional comments and warnings on Cef.DoMessageLoopWork). Enabling this option is not recommended for most users; + /// leave this option disabled and use either MultiThreadedMessageLoop (the default) if possible. + /// + public bool ExternalMessagePump + { + get { return settings.ExternalMessagePump; } + set { settings.ExternalMessagePump = value; } + } + + /// + /// Set to true to have the browser process message loop run in a separate thread. If false than the CefDoMessageLoopWork() + /// function must be called from your application message loop. This option is only supported on Windows. The default value is + /// true. + /// + public bool MultiThreadedMessageLoop + { + get { return settings.MultiThreadedMessageLoop; } + set { settings.MultiThreadedMessageLoop = value; } + } + + /// + /// The path to a separate executable that will be launched for sub-processes. By default the browser process executable is used. + /// See the comments on Cef.ExecuteProcess() for details. If this value is non-empty then it must be an absolute path. + /// Also configurable using the "browser-subprocess-path" command-line switch. + /// Defaults to using the provided CefSharp.BrowserSubprocess.exe instance + /// + public string BrowserSubprocessPath + { + get { return settings.BrowserSubprocessPath; } + set { settings.BrowserSubprocessPath = value; } + } + + /// + /// The location where data for the global browser cache will be stored on disk. In this value is non-empty then it must be + /// an absolute path that is must be either equal to or a child directory of CefSettings.RootCachePath (if RootCachePath is + /// empty it will default to this value). If the value is empty then browsers will be created in "incognito mode" where + /// in-memory caches are used for storage and no data is persisted to disk. HTML5 databases such as localStorage will only + /// persist across sessions if a cache path is specified. Can be overridden for individual RequestContext instances via the + /// RequestContextSettings.CachePath value. + /// + public string CachePath + { + get { return settings.CachePath; } + set { settings.CachePath = value; } + } + + /// + /// The root directory that all CefSettings.CachePath and RequestContextSettings.CachePath values must have in common. If this + /// value is empty and CefSettings.CachePath is non-empty then it will default to the CefSettings.CachePath value. + /// If this value is non-empty then it must be an absolute path. Failure to set this value correctly may result in the sandbox + /// blocking read/write access to the CachePath directory. NOTE: CefSharp does not implement the CHROMIUM SANDBOX. A non-empty + /// RootCachePath can be used in conjuncation with an empty CefSettings.CachePath in instances where you would like browsers + /// attached to the Global RequestContext (the default) created in "incognito mode" and instances created with a custom + /// RequestContext using a disk based cache. + /// + public string RootCachePath + { + get { return settings.RootCachePath; } + set { settings.RootCachePath = value; } + } + + /// + /// The location where user data such as spell checking dictionary files will be stored on disk. If this value is empty then the + /// default user data directory will be used ("Local Settings\Application Data\CEF\User Data" directory under the user + /// profile directory on Windows). If this value is non-empty then it must be an absolute path. + /// + public string UserDataPath + { + get { return settings.UserDataPath; } + set { settings.UserDataPath = value; } + } + + /// + /// Set to true in order to completely ignore SSL certificate errors. This is NOT recommended. + /// + public bool IgnoreCertificateErrors + { + get { return settings.IgnoreCertificateErrors; } + set { settings.IgnoreCertificateErrors = value; } + } + + /// + /// The locale string that will be passed to WebKit. If empty the default locale of "en-US" will be used. Also configurable using + /// the "lang" command-line switch. + /// + public string Locale + { + get { return settings.Locale; } + set { settings.Locale = value; } + } + + /// + /// The fully qualified path for the locales directory. If this value is empty the locales directory must be located in the + /// module directory. If this value is non-empty then it must be an absolute path. Also configurable using the "locales-dir-path" + /// command-line switch. + /// + public string LocalesDirPath + { + get { return settings.LocalesDirPath; } + set { settings.LocalesDirPath = value; } + } + + /// + /// The fully qualified path for the resources directory. If this value is empty the cef.pak and/or devtools_resources.pak files + /// must be located in the module directory. Also configurable using the "resources-dir-path" command-line switch. + /// + public string ResourcesDirPath + { + get { return settings.ResourcesDirPath; } + set { settings.ResourcesDirPath = value; } + } + + /// + /// The directory and file name to use for the debug log. If empty a default log file name and location will be used. On Windows + /// a "debug.log" file will be written in the main executable directory. Also configurable using the"log-file" command- line + /// switch. + /// + public string LogFile + { + get { return settings.LogFile; } + set { settings.LogFile = value; } + } + + /// + /// The log severity. Only messages of this severity level or higher will be logged. When set to + /// no messages will be written to the log file, but Fatal messages will still be + /// output to stderr. Also configurable using the "log-severity" command-line switch with a value of "verbose", "info", "warning", + /// "error", "fatal", "error-report" or "disable". + /// + public CefSharp.LogSeverity LogSeverity + { + get { return settings.LogSeverity; } + set { settings.LogSeverity = value; } + } + + /// + /// Custom flags that will be used when initializing the V8 JavaScript engine. The consequences of using custom flags may not be + /// well tested. Also configurable using the "js-flags" command-line switch. + /// + public string JavascriptFlags + { + get { return settings.JavascriptFlags; } + set { settings.JavascriptFlags = value; } + } + + /// + /// Set to true to disable loading of pack files for resources and locales. A resource bundle handler must be provided for the + /// browser and render processes via CefApp.GetResourceBundleHandler() if loading of pack files is disabled. Also configurable + /// using the "disable-pack-loading" command- line switch. + /// + public bool PackLoadingDisabled + { + get { return settings.PackLoadingDisabled; } + set { settings.PackLoadingDisabled = value; } + } + + /// + /// Value that will be inserted as the product portion of the default User-Agent string. If empty the Chromium product version + /// will be used. If UserAgent is specified this value will be ignored. Also configurable using the "product-version" command- + /// line switch. + /// + public string ProductVersion + { + get { return settings.ProductVersion; } + set { settings.ProductVersion = value; } + } + + /// + /// Set to a value between 1024 and 65535 to enable remote debugging on the specified port. For example, if 8080 is specified the + /// remote debugging URL will be http://localhost:8080. CEF can be remotely debugged from any CEF or Chrome browser window. Also + /// configurable using the "remote-debugging-port" command-line switch. + /// + public int RemoteDebuggingPort + { + get { return settings.RemoteDebuggingPort; } + set { settings.RemoteDebuggingPort = value; } + } + + /// + /// The number of stack trace frames to capture for uncaught exceptions. Specify a positive value to enable the + /// CefRenderProcessHandler. OnUncaughtException() callback. Specify 0 (default value) and OnUncaughtException() will not be + /// called. Also configurable using the "uncaught-exception-stack-size" command-line switch. + /// + public int UncaughtExceptionStackSize + { + get { return settings.UncaughtExceptionStackSize; } + set { settings.UncaughtExceptionStackSize = value; } + } + + /// + /// Value that will be returned as the User-Agent HTTP header. If empty the default User-Agent string will be used. Also + /// configurable using the "user-agent" command-line switch. + /// + public string UserAgent + { + get { return settings.UserAgent; } + set { settings.UserAgent = value; } + } + + /// + /// Set to true (1) to enable windowless (off-screen) rendering support. Do not enable this value if the application does not use + /// windowless rendering as it may reduce rendering performance on some systems. + /// + public bool WindowlessRenderingEnabled + { + get { return settings.WindowlessRenderingEnabled; } + set { settings.WindowlessRenderingEnabled = value; } + } + + /// + /// To persist session cookies (cookies without an expiry date or validity interval) by default when using the global cookie + /// manager set this value to true. Session cookies are generally intended to be transient and most Web browsers do not persist + /// them. A CachePath value must also be specified to enable this feature. Also configurable using the "persist-session-cookies" + /// command-line switch. Can be overridden for individual RequestContext instances via the + /// RequestContextSettings.PersistSessionCookies value. + /// + public bool PersistSessionCookies + { + get { return settings.PersistSessionCookies; } + set { settings.PersistSessionCookies = value; } + } + + /// + /// To persist user preferences as a JSON file in the cache path directory set this value to true. A CachePath value must also be + /// specified to enable this feature. Also configurable using the "persist-user-preferences" command-line switch. Can be + /// overridden for individual RequestContext instances via the RequestContextSettings.PersistUserPreferences value. + /// + public bool PersistUserPreferences + { + get { return settings.PersistUserPreferences; } + set { settings.PersistUserPreferences = value; } + } + + /// + /// Comma delimited ordered list of language codes without any whitespace that will be used in the "Accept-Language" HTTP header. + /// May be set globally using the CefSettings.AcceptLanguageList value. If both values are empty then "en-US,en" will be used. + /// + /// + public string AcceptLanguageList + { + get { return settings.AcceptLanguageList; } + set { settings.AcceptLanguageList = value; } + } + + /// + /// Background color used for the browser before a document is loaded and when no document color is specified. The alpha + /// component must be either fully opaque (0xFF) or fully transparent (0x00). If the alpha component is fully opaque then the RGB + /// components will be used as the background color. If the alpha component is fully transparent for a WinForms browser then the + /// default value of opaque white be used. If the alpha component is fully transparent for a windowless (WPF/OffScreen) browser + /// then transparent painting will be enabled. + /// + public UInt32 BackgroundColor + { + get { return settings.BackgroundColor; } + set { settings.BackgroundColor = value; } + } + + /// + /// GUID string used for identifying the application. This is passed to the system AV function for scanning downloaded files. By + /// default, the GUID will be an empty string and the file will be treated as an untrusted file when the GUID is empty. + /// + public string ApplicationClientIdForFileScanning + { + get { return settings.ApplicationClientIdForFileScanning; } + set { settings.ApplicationClientIdForFileScanning = value; } + } + + /// + /// Registers a custom scheme using the provided settings. + /// + /// The CefCustomScheme which provides the details about the scheme. + public void RegisterScheme(CefCustomScheme scheme) + { + settings.RegisterScheme(scheme); + } + + /// + /// Set command line argument to disable GPU Acceleration. WebGL will use + /// software rendering via Swiftshader (https://swiftshader.googlesource.com/SwiftShader#introduction) + /// + public void DisableGpuAcceleration() + { + if (!settings.CefCommandLineArgs.ContainsKey("disable-gpu")) + { + settings.CefCommandLineArgs.Add("disable-gpu"); + } + } + + /// + /// Set command line argument to enable Print Preview See + /// https://bitbucket.org/chromiumembedded/cef/issues/123/add-support-for-print-preview for details. + /// + public void EnablePrintPreview() + { + if (!settings.CefCommandLineArgs.ContainsKey("enable-print-preview")) + { + settings.CefCommandLineArgs.Add("enable-print-preview"); + } + } + + /// + /// Set command line arguments for best OSR (Offscreen and WPF) Rendering performance Swiftshader will be used for WebGL, look at the source + /// to determine which flags best suite your requirements. See https://swiftshader.googlesource.com/SwiftShader#introduction for + /// details on Swiftshader + /// + public void SetOffScreenRenderingBestPerformanceArgs() + { + // Use software rendering and compositing (disable GPU) for increased FPS + // and decreased CPU usage. + // See https://bitbucket.org/chromiumembedded/cef/issues/1257 for details. + if (!settings.CefCommandLineArgs.ContainsKey("disable-gpu")) + { + settings.CefCommandLineArgs.Add("disable-gpu"); + } + + if (!settings.CefCommandLineArgs.ContainsKey("disable-gpu-compositing")) + { + settings.CefCommandLineArgs.Add("disable-gpu-compositing"); + } + + // Synchronize the frame rate between all processes. This results in + // decreased CPU usage by avoiding the generation of extra frames that + // would otherwise be discarded. The frame rate can be set at browser + // creation time via IBrowserSettings.WindowlessFrameRate or changed + // dynamically using IBrowserHost.SetWindowlessFrameRate. In cefclient + // it can be set via the command-line using `--off-screen-frame-rate=XX`. + // See https://bitbucket.org/chromiumembedded/cef/issues/1368 for details. + if (!settings.CefCommandLineArgs.ContainsKey("enable-begin-frame-scheduling")) + { + settings.CefCommandLineArgs.Add("enable-begin-frame-scheduling"); + } + } + } + + /// + /// Create instance via + /// This is the primary object for bridging the ChromiumWebBrowser implementation and VC++ + /// + public static class ManagedCefBrowserAdapter + { + public static IBrowserAdapter Create(IWebBrowserInternal webBrowserInternal, bool offScreenRendering) + { + return new CefSharp.Core.ManagedCefBrowserAdapter(webBrowserInternal, offScreenRendering); + } + } + + /// + public static class NativeMethodWrapper + { + public static void MemoryCopy(IntPtr dest, IntPtr src, int numberOfBytes) + { + CefSharp.Core.NativeMethodWrapper.MemoryCopy(dest, src, numberOfBytes); + } + + public static bool IsFocused(IntPtr handle) + { + return CefSharp.Core.NativeMethodWrapper.IsFocused(handle); + } + + public static void SetWindowPosition(IntPtr handle, int x, int y, int width, int height) + { + CefSharp.Core.NativeMethodWrapper.SetWindowPosition(handle, x, y, width, height); + } + + public static void SetWindowParent(IntPtr child, IntPtr newParent) + { + CefSharp.Core.NativeMethodWrapper.SetWindowParent(child, newParent); + } + + public static void RemoveExNoActivateStyle(IntPtr browserHwnd) + { + CefSharp.Core.NativeMethodWrapper.RemoveExNoActivateStyle(browserHwnd); + } + } + + /// + public class PostData : CefSharp.Core.PostData + { + + } + + /// + public class PostDataElement : CefSharp.Core.PostDataElement + { + + } + + /// + public class Request : CefSharp.Core.Request + { + + } + + /// + public class RequestContext : CefSharp.Core.RequestContext + { + /// + public RequestContext() : base() + { + } + + /// + public RequestContext(CefSharp.IRequestContext otherRequestContext) : base(otherRequestContext) + { + + } + + /// + public RequestContext(CefSharp.IRequestContext otherRequestContext, CefSharp.IRequestContextHandler requestContextHandler) : base(otherRequestContext, requestContextHandler) + { + } + + /// + public RequestContext(CefSharp.IRequestContextHandler requestContextHandler) : base(requestContextHandler) + { + } + + /// + public RequestContext(CefSharp.RequestContextSettings settings) : base(settings.settings) + { + + } + + /// + public RequestContext(CefSharp.RequestContextSettings settings, CefSharp.IRequestContextHandler requestContextHandler) : base(settings.settings, requestContextHandler) + { + } + + /// + /// Creates a new RequestContextBuilder which can be used to fluently set + /// preferences + /// + /// Returns a new RequestContextBuilder + public static RequestContextBuilder Configure() + { + var builder = new RequestContextBuilder(); + + return builder; + } + } + + /// + /// Fluent style builder for creating IRequestContext instances. + /// + public class RequestContextBuilder + { + private RequestContextSettings _settings; + private IRequestContext _otherContext; + private RequestContextHandler _handler; + + void ThrowExceptionIfContextAlreadySet() + { + if (_otherContext != null) + { + throw new Exception("A call to WithSharedSettings has already been made, it is no possible to provide custom settings."); + } + } + + void ThrowExceptionIfCustomSettingSpecified() + { + if (_settings != null) + { + throw new Exception("A call to WithCachePath/PersistUserPreferences has already been made, it's not possible to share settings with another RequestContext."); + } + } + /// + /// Create the actual RequestContext instance + /// + /// Returns a new RequestContext instance. + public IRequestContext Create() + { + if (_otherContext != null) + { + return new CefSharp.Core.RequestContext(_otherContext, _handler); + } + + if (_settings != null) + { + return new CefSharp.Core.RequestContext(_settings.settings, _handler); + } + + return new CefSharp.Core.RequestContext(_handler); + } + + /// + /// Action is called in IRequestContextHandler.OnRequestContextInitialized + /// + /// called when the context has been initialized. + /// Returns RequestContextBuilder instance + public RequestContextBuilder OnInitialize(Action action) + { + if (_handler == null) + { + _handler = new RequestContextHandler(); + } + + _handler.OnInitialize(action); + + return this; + } + + /// + /// Sets the Cache Path + /// + /// + /// The location where cache data for this request context will be stored on + /// disk. If this value is non-empty then it must be an absolute path that is + /// either equal to or a child directory of CefSettings.RootCachePath. + /// If the value is empty then browsers will be created in "incognito mode" + /// where in-memory caches are used for storage and no data is persisted to disk. + /// HTML5 databases such as localStorage will only persist across sessions if a + /// cache path is specified. To share the global browser cache and related + /// configuration set this value to match the CefSettings.CachePath value. + /// + /// Returns RequestContextBuilder instance + public RequestContextBuilder WithCachePath(string cachePath) + { + ThrowExceptionIfContextAlreadySet(); + + if (_settings == null) + { + _settings = new RequestContextSettings(); + } + + _settings.CachePath = cachePath; + + return this; + } + + /// + /// Invoke this method tp persist user preferences as a JSON file in the cache path directory. + /// Can be set globally using the CefSettings.PersistUserPreferences value. + /// This value will be ignored if CachePath is empty or if it matches the CefSettings.CachePath value. + /// + /// Returns RequestContextBuilder instance + public RequestContextBuilder PersistUserPreferences() + { + ThrowExceptionIfContextAlreadySet(); + + if (_settings == null) + { + _settings = new RequestContextSettings(); + } + + _settings.PersistUserPreferences = true; + + return this; + } + + /// + /// Set the value associated with preference name when the RequestContext + /// is initialzied. If value is null the preference will be restored to its + /// default value. If setting the preference fails no error is throw, you + /// must check the CEF Log file. + /// Preferences set via the command-line usually cannot be modified. + /// + /// preference key + /// preference value + /// Returns RequestContextBuilder instance + public RequestContextBuilder WithPreference(string name, object value) + { + if (_handler == null) + { + _handler = new RequestContextHandler(); + } + + _handler.SetPreferenceOnContextInitialized(name, value); + + return this; + } + + /// + /// Set the Proxy server when the RequestContext is initialzied. + /// If value is null the preference will be restored to its + /// default value. If setting the preference fails no error is throw, you + /// must check the CEF Log file. + /// Proxy set via the command-line cannot be modified. + /// + /// proxy host + /// Returns RequestContextBuilder instance + public RequestContextBuilder WithProxyServer(string host) + { + if (_handler == null) + { + _handler = new RequestContextHandler(); + } + + _handler.SetProxyOnContextInitialized(host, null); + + return this; + } + + /// + /// Set the Proxy server when the RequestContext is initialzied. + /// If value is null the preference will be restored to its + /// default value. If setting the preference fails no error is throw, you + /// must check the CEF Log file. + /// Proxy set via the command-line cannot be modified. + /// + /// proxy host + /// proxy port (optional) + /// Returns RequestContextBuilder instance + public RequestContextBuilder WithProxyServer(string host, int? port) + { + if (_handler == null) + { + _handler = new RequestContextHandler(); + } + + _handler.SetProxyOnContextInitialized(host, port); + + return this; + } + + /// + /// Set the Proxy server when the RequestContext is initialzied. + /// If value is null the preference will be restored to its + /// default value. If setting the preference fails no error is throw, you + /// must check the CEF Log file. + /// Proxy set via the command-line cannot be modified. + /// + /// proxy scheme + /// proxy host + /// proxy port (optional) + /// Returns RequestContextBuilder instance + public RequestContextBuilder WithProxyServer(string scheme, string host, int? port) + { + if (_handler == null) + { + _handler = new RequestContextHandler(); + } + + _handler.SetProxyOnContextInitialized(scheme, host, port); + + return this; + } + + /// + /// Shares storage with other RequestContext + /// + /// shares storage with this RequestContext + /// Returns RequestContextBuilder instance + public RequestContextBuilder WithSharedSettings(IRequestContext other) + { + if (other == null) + { + throw new ArgumentNullException("other"); + } + + ThrowExceptionIfCustomSettingSpecified(); + + _otherContext = other; + + return this; + } + } + + /// + public class RequestContextSettings + { + internal Core.RequestContextSettings settings = new Core.RequestContextSettings(); + + /// + /// To persist session cookies (cookies without an expiry date or validity + /// interval) by default when using the global cookie manager set this value to + /// true. Session cookies are generally intended to be transient and most + /// Web browsers do not persist them. Can be set globally using the + /// CefSettings.PersistSessionCookies value. This value will be ignored if + /// CachePath is empty or if it matches the CefSettings.CachePath value. + /// + public bool PersistSessionCookies + { + get { return settings.PersistSessionCookies; } + set { settings.PersistSessionCookies = value; } + } + + /// + /// To persist user preferences as a JSON file in the cache path directory set + /// this value to true. Can be set globally using the + /// CefSettings.PersistUserPreferences value. This value will be ignored if + /// CachePath is empty or if it matches the CefSettings.CachePath value. + /// + public bool PersistUserPreferences + { + get { return settings.PersistUserPreferences; } + set { settings.PersistUserPreferences = value; } + } + + /// + /// The location where cache data for this request context will be stored on + /// disk. If this value is non-empty then it must be an absolute path that is + /// either equal to or a child directory of CefSettings.RootCachePath. + /// If the value is empty then browsers will be created in "incognito mode" + /// where in-memory caches are used for storage and no data is persisted to disk. + /// HTML5 databases such as localStorage will only persist across sessions if a + /// cache path is specified. To share the global browser cache and related + /// configuration set this value to match the CefSettings.CachePath value. + /// + public String CachePath + { + get { return settings.CachePath; } + set { settings.CachePath = value; } + } + + /// + /// Comma delimited ordered list of language codes without any whitespace that + /// will be used in the "Accept-Language" HTTP header. Can be set globally + /// using the CefSettings.accept_language_list value or overridden on a per- + /// browser basis using the BrowserSettings.AcceptLanguageList value. If + /// all values are empty then "en-US,en" will be used. This value will be + /// ignored if CachePath matches the CefSettings.CachePath value. + /// + public String AcceptLanguageList + { + get { return settings.AcceptLanguageList; } + set { settings.AcceptLanguageList = value; } + } + + /// + /// Set to true to ignore errors related to invalid SSL certificates. + /// Enabling this setting can lead to potential security vulnerabilities like + /// "man in the middle" attacks. Applications that load content from the + /// internet should not enable this setting. Can be set globally using the + /// CefSettings.IgnoreCertificateErrors value. This value will be ignored if + /// CachePath matches the CefSettings.cache_path value. + /// + public bool IgnoreCertificateErrors + { + get { return settings.IgnoreCertificateErrors; } + set { settings.IgnoreCertificateErrors = value; } + } + } + + /// + public class UrlRequest : CefSharp.Core.UrlRequest + { + public UrlRequest(IRequest request, IUrlRequestClient urlRequestClient) : base(request, urlRequestClient) + { + } + + public UrlRequest(IRequest request, IUrlRequestClient urlRequestClient, IRequestContext requestContext) : base(request, urlRequestClient, requestContext) + { + } + } + + /// + public class WindowInfo : CefSharp.Core.WindowInfo + { + + } + + public static class DragData + { + public static IDragData Create() + { + return Core.DragData.Create(); + } + } +} diff --git a/CefSharp.Core/Request.cpp b/CefSharp.Core/Request.cpp deleted file mode 100644 index ca1e61b845..0000000000 --- a/CefSharp.Core/Request.cpp +++ /dev/null @@ -1,210 +0,0 @@ -// Copyright © 2010 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#include "Stdafx.h" -#include "Request.h" -#include "PostData.h" - -using namespace System::Text; - -namespace CefSharp -{ - UrlRequestFlags Request::Flags::get() - { - ThrowIfDisposed(); - - return (UrlRequestFlags)_request->GetFlags(); - } - - void Request::Flags::set(UrlRequestFlags flags) - { - ThrowIfDisposed(); - ThrowIfReadOnly(); - - _request->SetFlags((int)flags); - } - - String^ Request::Url::get() - { - ThrowIfDisposed(); - - return StringUtils::ToClr(_request->GetURL()); - } - - void Request::Url::set(String^ url) - { - if (url == nullptr) - { - throw gcnew System::ArgumentException("cannot be null", "url"); - } - - ThrowIfDisposed(); - ThrowIfReadOnly(); - - CefString str = StringUtils::ToNative(url); - _request->SetURL(str); - } - - String^ Request::Method::get() - { - ThrowIfDisposed(); - - return StringUtils::ToClr(_request->GetMethod()); - } - - void Request::Method::set(String^ method) - { - if (method == nullptr) - { - throw gcnew System::ArgumentException("cannot be null", "method"); - } - - ThrowIfDisposed(); - ThrowIfReadOnly(); - - _request->SetMethod(StringUtils::ToNative(method)); - } - - UInt64 Request::Identifier::get() - { - ThrowIfDisposed(); - - return _request->GetIdentifier(); - } - - void Request::SetReferrer(String^ referrerUrl, CefSharp::ReferrerPolicy policy) - { - ThrowIfDisposed(); - ThrowIfReadOnly(); - - _request->SetReferrer(StringUtils::ToNative(referrerUrl), (cef_referrer_policy_t)policy); - } - - String^ Request::ReferrerUrl::get() - { - ThrowIfDisposed(); - - return StringUtils::ToClr(_request->GetReferrerURL()); - } - - CefSharp::ResourceType Request::ResourceType::get() - { - ThrowIfDisposed(); - - return (CefSharp::ResourceType)_request->GetResourceType(); - } - - CefSharp::ReferrerPolicy Request::ReferrerPolicy::get() - { - ThrowIfDisposed(); - - return (CefSharp::ReferrerPolicy)_request->GetReferrerPolicy(); - } - - NameValueCollection^ Request::Headers::get() - { - ThrowIfDisposed(); - - CefRequest::HeaderMap hm; - _request->GetHeaderMap(hm); - - auto headers = gcnew HeaderNameValueCollection(); - - for (CefRequest::HeaderMap::iterator it = hm.begin(); it != hm.end(); ++it) - { - String^ name = StringUtils::ToClr(it->first); - String^ value = StringUtils::ToClr(it->second); - headers->Add(name, value); - } - - if (_request->IsReadOnly()) - { - headers->SetReadOnly(); - } - - return headers; - } - - void Request::Headers::set(NameValueCollection^ headers) - { - ThrowIfDisposed(); - ThrowIfReadOnly(); - - CefRequest::HeaderMap hm; - - for each(String^ key in headers) - { - CefString name = StringUtils::ToNative(key); - for each(String^ element in headers->GetValues(key)) - { - CefString value = StringUtils::ToNative(element); - hm.insert(std::make_pair(name, value)); - } - } - - _request->SetHeaderMap(hm); - } - - TransitionType Request::TransitionType::get() - { - ThrowIfDisposed(); - - return (CefSharp::TransitionType) _request->GetTransitionType(); - } - - IPostData^ Request::PostData::get() - { - ThrowIfDisposed(); - - if (_postData == nullptr) - { - auto postData = _request->GetPostData(); - if (postData.get()) - { - _postData = gcnew CefSharp::PostData(postData); - } - } - return _postData; - } - - void Request::PostData::set(IPostData^ postData) - { - ThrowIfDisposed(); - - ThrowIfReadOnly(); - - _request->SetPostData((CefSharp::PostData^)postData); - } - - bool Request::IsReadOnly::get() - { - ThrowIfDisposed(); - - return _request->IsReadOnly(); - } - - void Request::InitializePostData() - { - ThrowIfDisposed(); - - ThrowIfReadOnly(); - - _request->SetPostData(CefPostData::Create()); - } - - String^ Request::GetHeaderByName(String^ name) - { - ThrowIfDisposed(); - - return StringUtils::ToClr(_request->GetHeaderByName(StringUtils::ToNative(name))); - } - - void Request::SetHeaderByName(String^ name, String^ value, bool overwrite) - { - ThrowIfDisposed(); - ThrowIfReadOnly(); - - _request->SetHeaderByName(StringUtils::ToNative(name), StringUtils::ToNative(value), overwrite); - } -} diff --git a/CefSharp.Core/Request.h b/CefSharp.Core/Request.h deleted file mode 100644 index 40e8d500cd..0000000000 --- a/CefSharp.Core/Request.h +++ /dev/null @@ -1,80 +0,0 @@ -// Copyright © 2010 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" - -#include "include\cef_request.h" -#include "Internals\CefWrapper.h" - -using namespace System::Collections::Specialized; - -namespace CefSharp -{ - public ref class Request : public IRequest, public CefWrapper - { - MCefRefPtr _request; - IPostData^ _postData; - internal: - Request(CefRefPtr &cefRequest) : - _request(cefRequest), _postData(nullptr) - { - } - - !Request() - { - _request = nullptr; - } - - ~Request() - { - this->!Request(); - - delete _postData; - - _disposed = true; - } - - operator CefRefPtr() - { - if (this == nullptr) - { - return NULL; - } - return _request.get(); - } - - void ThrowIfReadOnly() - { - if (_request->IsReadOnly()) - { - throw gcnew NotSupportedException("IRequest is read-only and cannot be modified. Check IRequest.IsReadOnly to guard against this exception."); - } - } - - public: - Request() - { - _request = CefRequest::Create(); - } - - virtual property UrlRequestFlags Flags { UrlRequestFlags get(); void set(UrlRequestFlags flags); } - virtual property String^ Url { String^ get(); void set(String^ url); } - virtual property String^ Method { String^ get(); void set(String^ method); } - virtual property UInt64 Identifier { UInt64 get(); } - virtual void SetReferrer(String^ referrerUrl, CefSharp::ReferrerPolicy policy); - virtual property String^ ReferrerUrl { String^ get(); } - virtual property ResourceType ResourceType { CefSharp::ResourceType get(); } - virtual property ReferrerPolicy ReferrerPolicy { CefSharp::ReferrerPolicy get(); } - virtual property NameValueCollection^ Headers { NameValueCollection^ get(); void set(NameValueCollection^ url); } - virtual property TransitionType TransitionType { CefSharp::TransitionType get(); } - virtual property IPostData^ PostData { IPostData^ get(); void set(IPostData^ postData); } - virtual property bool IsReadOnly { bool get(); } - virtual void InitializePostData(); - - virtual String^ GetHeaderByName(String^ name); - virtual void SetHeaderByName(String^ name, String^ value, bool overwrite); - }; -} diff --git a/CefSharp.Core/RequestContext.cpp b/CefSharp.Core/RequestContext.cpp deleted file mode 100644 index 405476b993..0000000000 --- a/CefSharp.Core/RequestContext.cpp +++ /dev/null @@ -1,269 +0,0 @@ -// Copyright © 2015 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#include "Stdafx.h" -#include "RequestContext.h" - -#include "include\cef_parser.h" - -//For the x86 version we define and undefine CEF_INCLUDE_BASE_INTERNAL_CEF_BIND_INTERNAL_WIN_H_ -//as the /clr compliation option attempts to be helpful and convers all the __fastcall versions -//to __stdcall which already exist, so we just use the standard calling convention and ignore -//the optimised ones. The original error is -//warning C4561: '__fastcall' incompatible with the '/clr' option: converting to '__stdcall' -//(compiling source file RequestContext.cpp) -#define CEF_INCLUDE_BASE_INTERNAL_CEF_BIND_INTERNAL_WIN_H_ -#include "include\base\cef_bind.h" -#undef CEF_INCLUDE_BASE_INTERNAL_CEF_BIND_INTERNAL_WIN_H_ - -#include "include\wrapper\cef_closure_task.h" - -#include "CookieManager.h" -#include "Internals\CefSchemeHandlerFactoryAdapter.h" -#include "Internals\CefCompletionCallbackAdapter.h" -#include "Internals\CefExtensionWrapper.h" -#include "Internals\CefExtensionHandlerAdapter.h" -#include "Internals\CefResolveCallbackAdapter.h" -#include "Internals\TypeConversion.h" - -using namespace System::Runtime::InteropServices; - -namespace CefSharp -{ - bool RequestContext::IsSame(IRequestContext^ context) - { - ThrowIfDisposed(); - - auto requestContext = (RequestContext^)context; - - return _requestContext->IsSame(requestContext); - } - - bool RequestContext::IsSharingWith(IRequestContext^ context) - { - ThrowIfDisposed(); - - auto requestContext = (RequestContext^)context; - - return _requestContext->IsSharingWith(requestContext); - } - - ICookieManager^ RequestContext::GetCookieManager(ICompletionCallback^ callback) - { - ThrowIfDisposed(); - - CefRefPtr wrapper = callback == nullptr ? NULL : new CefCompletionCallbackAdapter(callback); - - auto cookieManager = _requestContext->GetCookieManager(wrapper); - if (cookieManager.get()) - { - return gcnew CookieManager(cookieManager); - } - return nullptr; - } - - bool RequestContext::RegisterSchemeHandlerFactory(String^ schemeName, String^ domainName, ISchemeHandlerFactory^ factory) - { - ThrowIfDisposed(); - - auto wrapper = new CefSchemeHandlerFactoryAdapter(factory); - return _requestContext->RegisterSchemeHandlerFactory(StringUtils::ToNative(schemeName), StringUtils::ToNative(domainName), wrapper); - } - - bool RequestContext::ClearSchemeHandlerFactories() - { - ThrowIfDisposed(); - - return _requestContext->ClearSchemeHandlerFactories(); - } - - void RequestContext::PurgePluginListCache(bool reloadPages) - { - ThrowIfDisposed(); - - _requestContext->PurgePluginListCache(reloadPages); - } - - bool RequestContext::HasPreference(String^ name) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - return _requestContext->HasPreference(StringUtils::ToNative(name)); - } - - Object^ RequestContext::GetPreference(String^ name) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - return TypeConversion::FromNative(_requestContext->GetPreference(StringUtils::ToNative(name))); - } - - IDictionary^ RequestContext::GetAllPreferences(bool includeDefaults) - { - ThrowIfDisposed(); - - auto preferences = _requestContext->GetAllPreferences(includeDefaults); - - return TypeConversion::FromNative(preferences); - } - - bool RequestContext::CanSetPreference(String^ name) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - return _requestContext->CanSetPreference(StringUtils::ToNative(name)); - } - - bool RequestContext::SetPreference(String^ name, Object^ value, [Out] String^ %error) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - CefString cefError; - - auto success = _requestContext->SetPreference(StringUtils::ToNative(name), TypeConversion::ToNative(value), cefError); - - error = StringUtils::ToClr(cefError); - - return success; - } - - void RequestContext::ClearCertificateExceptions(ICompletionCallback^ callback) - { - ThrowIfDisposed(); - - CefRefPtr wrapper = callback == nullptr ? NULL : new CefCompletionCallbackAdapter(callback); - - _requestContext->ClearCertificateExceptions(wrapper); - } - - void RequestContext::ClearHttpAuthCredentials(ICompletionCallback^ callback) - { - ThrowIfDisposed(); - - //TODO: Remove this once CEF Issue has been resolved - //ClearHttpAuthCredentials crashes when no callback specified - if (callback == nullptr) - { - callback = gcnew CefSharp::Callback::NoOpCompletionCallback(); - } - - CefRefPtr wrapper = callback == nullptr ? NULL : new CefCompletionCallbackAdapter(callback); - - _requestContext->ClearHttpAuthCredentials(wrapper); - } - - void RequestContext::CloseAllConnections(ICompletionCallback^ callback) - { - ThrowIfDisposed(); - - CefRefPtr wrapper = callback == nullptr ? NULL : new CefCompletionCallbackAdapter(callback); - - _requestContext->CloseAllConnections(wrapper); - } - - Task^ RequestContext::ResolveHostAsync(Uri^ origin) - { - ThrowIfDisposed(); - - auto callback = gcnew TaskResolveCallback(); - - CefRefPtr callbackWrapper = new CefResolveCallbackAdapter(callback); - - _requestContext->ResolveHost(StringUtils::ToNative(origin->AbsoluteUri), callbackWrapper); - - return callback->Task; - } - - bool RequestContext::DidLoadExtension(String^ extensionId) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - return _requestContext->DidLoadExtension(StringUtils::ToNative(extensionId)); - } - - IExtension^ RequestContext::GetExtension(String^ extensionId) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - auto extension = _requestContext->GetExtension(StringUtils::ToNative(extensionId)); - - if (extension.get()) - { - return gcnew CefExtensionWrapper(extension); - } - - return nullptr; - } - - bool RequestContext::GetExtensions([Out] IList^ %extensionIds) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - std::vector extensions; - - auto success = _requestContext->GetExtensions(extensions); - - extensionIds = StringUtils::ToClr(extensions); - - return success; - } - - bool RequestContext::HasExtension(String^ extensionId) - { - ThrowIfDisposed(); - - ThrowIfExecutedOnNonCefUiThread(); - - return _requestContext->HasExtension(StringUtils::ToNative(extensionId)); - } - - void RequestContext::LoadExtension(String^ rootDirectory, String^ manifestJson, IExtensionHandler^ handler) - { - ThrowIfDisposed(); - - CefRefPtr manifest; - - if (!String::IsNullOrEmpty(manifestJson)) - { - CefString errorMessage; - auto value = CefParseJSONAndReturnError(StringUtils::ToNative(manifestJson), - cef_json_parser_options_t::JSON_PARSER_ALLOW_TRAILING_COMMAS, - errorMessage); - - if (value.get()) - { - manifest = value->GetDictionary(); - } - else - { - throw gcnew Exception("Unable to parse JSON - ErrorMessage:" + StringUtils::ToClr(errorMessage)); - } - } - - CefRefPtr extensionHandler = handler == nullptr ? NULL : new CefExtensionHandlerAdapter(handler); - - if (CefCurrentlyOn(CefThreadId::TID_UI)) - { - _requestContext->LoadExtension(StringUtils::ToNative(rootDirectory), manifest, extensionHandler); - } - else - { - CefPostTask(TID_UI, base::Bind(&CefRequestContext::LoadExtension, _requestContext.get(), StringUtils::ToNative(rootDirectory), manifest, extensionHandler)); - } - } -} diff --git a/CefSharp.Core/RequestContext.h b/CefSharp.Core/RequestContext.h deleted file mode 100644 index 1f377fea76..0000000000 --- a/CefSharp.Core/RequestContext.h +++ /dev/null @@ -1,411 +0,0 @@ -// Copyright © 2015 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#ifndef CEFSHARP_CORE_REQUESTCONTEXT_H_ -#define CEFSHARP_CORE_REQUESTCONTEXT_H_ - -#pragma once - -#include "Stdafx.h" -#include "include\cef_request_context.h" - -#include "RequestContextSettings.h" -#include "RequestContextBuilder.h" -#include "Internals\CefRequestContextHandlerAdapter.h" -#include "Internals\CefWrapper.h" - -using namespace System::Runtime::InteropServices; -using namespace System::Threading::Tasks; - -namespace CefSharp -{ - /// - /// A request context provides request handling for a set of related browser objects. - /// A request context is specified when creating a new browser object via the CefBrowserHost - /// static factory methods. Browser objects with different request contexts will never be - /// hosted in the same render process. Browser objects with the same request context may or - /// may not be hosted in the same render process depending on the process model. - /// Browser objects created indirectly via the JavaScript window.open function or targeted - /// links will share the same render process and the same request context as the source browser. - /// When running in single-process mode there is only a single render process (the main process) - /// and so all browsers created in single-process mode will share the same request context. - /// This will be the first request context passed into a CefBrowserHost static factory method - /// and all other request context objects will be ignored. - /// - public ref class RequestContext : public IRequestContext, public CefWrapper - { - private: - MCefRefPtr _requestContext; - RequestContextSettings^ _settings; - - internal: - RequestContext(CefRefPtr& context) - { - _requestContext = context; - _settings = nullptr; - } - - operator CefRefPtr() - { - if (this == nullptr) - { - return NULL; - } - return _requestContext.get(); - } - - public: - RequestContext() - { - CefRequestContextSettings settings; - _requestContext = CefRequestContext::CreateContext(settings, NULL); - } - - RequestContext(RequestContextSettings^ settings) : _settings(settings) - { - PathCheck::AssertAbsolute(settings->CachePath, "RequestContextSettings.CachePath"); - - _requestContext = CefRequestContext::CreateContext(settings, NULL); - } - - RequestContext(IRequestContextHandler^ requestContextHandler) - { - CefRequestContextSettings settings; - _requestContext = CefRequestContext::CreateContext(settings, new CefRequestContextHandlerAdapter(requestContextHandler)); - } - - RequestContext(RequestContextSettings^ settings, IRequestContextHandler^ requestContextHandler) : _settings(settings) - { - PathCheck::AssertAbsolute(settings->CachePath, "RequestContextSettings.CachePath"); - - _requestContext = CefRequestContext::CreateContext(settings, new CefRequestContextHandlerAdapter(requestContextHandler)); - } - - ///Creates a new context object that shares storage with | other | and uses an optional | handler | . - RequestContext(IRequestContext^ otherRequestContext) - { - _requestContext = CefRequestContext::CreateContext((RequestContext^)otherRequestContext, NULL); - } - - RequestContext(IRequestContext^ otherRequestContext, IRequestContextHandler^ requestContextHandler) - { - _requestContext = CefRequestContext::CreateContext((RequestContext^)otherRequestContext, new CefRequestContextHandlerAdapter(requestContextHandler)); - } - - !RequestContext() - { - _requestContext = NULL; - } - - ~RequestContext() - { - this->!RequestContext(); - - delete _settings; - - _disposed = true; - } - - /// - /// Creates a new context object that shares storage with other and uses an - /// optional handler. - /// - /// shares storage with this RequestContext - /// optional requestContext handler - /// Returns a new RequestContext - static IRequestContext^ CreateContext(IRequestContext^ other, IRequestContextHandler^ requestContextHandler) - { - auto otherRequestContext = static_cast(other); - CefRefPtr handler = requestContextHandler == nullptr ? NULL : new CefRequestContextHandlerAdapter(requestContextHandler); - - auto newContext = CefRequestContext::CreateContext(otherRequestContext, handler); - return gcnew RequestContext(newContext); - } - - /// - /// Creates a new RequestContextBuilder which can be used to fluently set - /// preferences - /// - /// Returns a new RequestContextBuilder - static RequestContextBuilder^ Configure() - { - auto builder = gcnew RequestContextBuilder(); - - return builder; - } - - /// - /// Returns true if this object is pointing to the same context object. - /// - /// context to compare - /// Returns true if the same - virtual bool IsSame(IRequestContext^ context); - - /// - /// Returns true if this object is sharing the same storage as the specified context. - /// - /// context to compare - /// Returns true if same storage - virtual bool IsSharingWith(IRequestContext^ context); - - /// - /// Returns the default cookie manager for this object. This will be the global - /// cookie manager if this object is the global request context. - /// - /// If callback is non-NULL it will be executed asnychronously on the CEF IO thread - /// after the manager's storage has been initialized. - /// Returns the default cookie manager for this object - virtual ICookieManager^ GetCookieManager(ICompletionCallback^ callback); - - /// - /// Returns true if this object is the global context. The global context is - /// used by default when creating a browser or URL request with a NULL context - /// argument. - /// - virtual property bool IsGlobal - { - bool get() - { - ThrowIfDisposed(); - return _requestContext->IsGlobal(); - } - } - - /// - /// Register a scheme handler factory for the specified schemeName and optional domainName. - /// An empty domainName value for a standard scheme will cause the factory to match all domain - /// names. The domainName value will be ignored for non-standard schemes. If schemeName is - /// a built-in scheme and no handler is returned by factory then the built-in scheme handler - /// factory will be called. If schemeName is a custom scheme then you must also implement the - /// IApp.OnRegisterCustomSchemes() method in all processes. This function may be called multiple - /// times to change or remove the factory that matches the specified schemeName and optional - /// domainName. - /// - /// Scheme Name - /// Optional domain name - /// Scheme handler factory - /// Returns false if an error occurs. - virtual bool RegisterSchemeHandlerFactory(String^ schemeName, String^ domainName, ISchemeHandlerFactory^ factory); - - /// - /// Clear all registered scheme handler factories. - /// - /// Returns false on error. - virtual bool ClearSchemeHandlerFactories(); - - /// - /// Returns the cache path for this object. If empty an "incognito mode" - /// in-memory cache is being used. - /// - virtual property String^ CachePath - { - String^ get() - { - ThrowIfDisposed(); - - return StringUtils::ToClr(_requestContext->GetCachePath()); - } - } - - /// - /// Tells all renderer processes associated with this context to throw away - /// their plugin list cache. If reloadPages is true they will also reload - /// all pages with plugins. RequestContextHandler.OnBeforePluginLoad may - /// be called to rebuild the plugin list cache. - /// - /// reload any pages with pluginst - virtual void PurgePluginListCache(bool reloadPages); - - /// - /// Returns true if a preference with the specified name exists. This method - /// must be called on the CEF UI thread. - /// - /// name of preference - /// bool if the preference exists - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual bool HasPreference(String^ name); - - /// - /// Returns the value for the preference with the specified name. Returns - /// NULL if the preference does not exist. The returned object contains a copy - /// of the underlying preference value and modifications to the returned object - /// will not modify the underlying preference value. This method must be called - /// on the CEF UI thread. - /// - /// preference name - /// Returns the value for the preference with the specified name - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual Object^ GetPreference(String^ name); - - /// - /// Returns all preferences as a dictionary. The returned - /// object contains a copy of the underlying preference values and - /// modifications to the returned object will not modify the underlying - /// preference values. This method must be called on the browser process UI - /// thread. - /// - /// If true then - /// preferences currently at their default value will be included. - /// Preferences (dictionary can have sub dictionaries) - virtual IDictionary^ GetAllPreferences(bool includeDefaults); - - /// - /// Returns true if the preference with the specified name can be modified - /// using SetPreference. As one example preferences set via the command-line - /// usually cannot be modified. This method must be called on the CEF UI thread. - /// - /// preference key - /// Returns true if the preference with the specified name can be modified - /// using SetPreference - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual bool CanSetPreference(String^ name); - - /// - /// Set the value associated with preference name. If value is null the - /// preference will be restored to its default value. If setting the preference - /// fails then error will be populated with a detailed description of the - /// problem. This method must be called on the CEF UI thread. - /// Preferences set via the command-line usually cannot be modified. - /// - /// preference key - /// preference value - /// out error - /// Returns true if the value is set successfully and false otherwise. - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual bool SetPreference(String^ name, Object^ value, [Out] String^ %error); - - /// - /// Clears all certificate exceptions that were added as part of handling - /// . If you call this it is - /// recommended that you also call or you risk not - /// being prompted again for server certificates if you reconnect quickly. - /// - /// If is non-NULL it will be executed on the CEF UI thread after - /// completion. This param is optional - virtual void ClearCertificateExceptions(ICompletionCallback^ callback); - - /// - /// Clears all HTTP authentication credentials that were added as part of handling - /// . - /// - /// If is non-NULL it will be executed on the CEF UI thread after - /// completion. This param is optional - virtual void ClearHttpAuthCredentials(ICompletionCallback^ callback); - - /// - /// Clears all active and idle connections that Chromium currently has. - /// This is only recommended if you have released all other CEF objects but - /// don't yet want to call Cef.Shutdown(). - /// - /// If is non-NULL it will be executed on the CEF UI thread after - /// completion. This param is optional - virtual void CloseAllConnections(ICompletionCallback^ callback); - - /// - /// Attempts to resolve origin to a list of associated IP addresses. - /// - /// host name to resolve - /// A task that represents the Resoolve Host operation. The value of the TResult parameter contains ResolveCallbackResult. - virtual Task^ ResolveHostAsync(Uri^ origin); - - /// - /// Returns true if this context was used to load the extension identified by extensionId. Other contexts sharing the same storage will also have access to the extension (see HasExtension). - /// This method must be called on the CEF UI thread. - /// - /// Returns true if this context was used to load the extension identified by extensionId - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual bool DidLoadExtension(String^ extensionId); - - /// - /// Returns the extension matching extensionId or null if no matching extension is accessible in this context (see HasExtension). - /// This method must be called on the CEF UI thread. - /// - /// extension Id - /// Returns the extension matching extensionId or null if no matching extension is accessible in this context - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual IExtension^ GetExtension(String^ extensionId); - - /// - /// Retrieve the list of all extensions that this context has access to (see HasExtension). - /// will be populated with the list of extension ID values. - /// This method must be called on the CEF UI thread. - /// - /// output a list of extensions Ids - /// returns true on success otherwise false - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual bool GetExtensions([Out] IList^ %extensionIds); - - /// - /// Returns true if this context has access to the extension identified by extensionId. - /// This may not be the context that was used to load the extension (see DidLoadExtension). - /// This method must be called on the CEF UI thread. - /// - /// extension id - /// Returns true if this context has access to the extension identified by extensionId - /// Use Cef.UIThreadTaskFactory to execute this method if required, - /// and ChromiumWebBrowser.IsBrowserInitializedChanged are both - /// executed on the CEF UI thread, so can be called directly. - /// When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main - /// application thread will be the CEF UI thread. - virtual bool HasExtension(String^ extensionId); - - /// - /// Load an extension. If extension resources will be read from disk using the default load implementation then rootDirectoy - /// should be the absolute path to the extension resources directory and manifestJson should be null. - /// If extension resources will be provided by the client (e.g. via IRequestHandler and/or IExtensionHandler) then rootDirectory - /// should be a path component unique to the extension (if not absolute this will be internally prefixed with the PK_DIR_RESOURCES path) - /// and manifestJson should contain the contents that would otherwise be read from the "manifest.json" file on disk. - /// The loaded extension will be accessible in all contexts sharing the same storage (HasExtension returns true). - /// However, only the context on which this method was called is considered the loader (DidLoadExtension returns true) and only the - /// loader will receive IRequestContextHandler callbacks for the extension. will be - /// called on load success or will be called on load failure. - /// If the extension specifies a background script via the "background" manifest key then - /// will be called to create the background browser. See that method for additional information about background scripts. - /// For visible extension views the client application should evaluate the manifest to determine the correct extension URL to load and then pass - /// that URL to the IBrowserHost.CreateBrowser* function after the extension has loaded. For example, the client can look for the "browser_action" - /// manifest key as documented at https://developer.chrome.com/extensions/browserAction. Extension URLs take the form "chrome-extension:///". - /// Browsers that host extensions differ from normal browsers as follows: - Can access chrome.* JavaScript APIs if allowed by the manifest. - /// Visit chrome://extensions-support for the list of extension APIs currently supported by CEF. - Main frame navigation to non-extension - /// content is blocked. - /// - Pinch-zooming is disabled. - /// - returns the hosted extension. - /// - CefBrowserHost::IsBackgroundHost returns true for background hosts. See https://developer.chrome.com/extensions for extension implementation and usage documentation. - /// - /// If extension resources will be read from disk using the default load implementation then rootDirectoy - /// should be the absolute path to the extension resources directory and manifestJson should be null - /// If extension resources will be provided by the client then rootDirectory should be a path component unique to the extension - /// and manifestJson should contain the contents that would otherwise be read from the manifest.json file on disk - /// handle events related to browser extensions - virtual void LoadExtension(String^ rootDirectory, String^ manifestJson, IExtensionHandler^ handler); - }; -} -#endif // CEFSHARP_CORE_REQUESTCONTEXT_H_ diff --git a/CefSharp.Core/RequestContextBuilder.cpp b/CefSharp.Core/RequestContextBuilder.cpp deleted file mode 100644 index dafe57c989..0000000000 --- a/CefSharp.Core/RequestContextBuilder.cpp +++ /dev/null @@ -1,127 +0,0 @@ -// Copyright © 2020 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#include "Stdafx.h" -#include "RequestContextBuilder.h" -#include "RequestContext.h" - -namespace CefSharp -{ - IRequestContext^ RequestContextBuilder::Create() - { - if (_otherContext != nullptr) - { - return gcnew RequestContext(_otherContext, _handler); - } - - if(_settings != nullptr) - { - return gcnew RequestContext(_settings, _handler); - } - - return gcnew RequestContext(_handler); - } - - RequestContextBuilder^ RequestContextBuilder::OnInitialize(Action^ action) - { - if (_handler == nullptr) - { - _handler = gcnew RequestContextHandler(); - } - - _handler->OnInitialize(action); - - return this; - } - - RequestContextBuilder^ RequestContextBuilder::WithPreference(String^ name, Object^ value) - { - if (_handler == nullptr) - { - _handler = gcnew RequestContextHandler(); - } - - _handler->SetPreferenceOnContextInitialized(name, value); - - return this; - } - - RequestContextBuilder^ RequestContextBuilder::WithProxyServer(String^ host) - { - if (_handler == nullptr) - { - _handler = gcnew RequestContextHandler(); - } - - _handler->SetProxyOnContextInitialized(host, Nullable()); - - return this; - } - - RequestContextBuilder^ RequestContextBuilder::WithProxyServer(String^ host, Nullable port) - { - if (_handler == nullptr) - { - _handler = gcnew RequestContextHandler(); - } - - _handler->SetProxyOnContextInitialized(host, port); - - return this; - } - - RequestContextBuilder^ RequestContextBuilder::WithProxyServer(String^ scheme, String^ host, Nullable port) - { - if (_handler == nullptr) - { - _handler = gcnew RequestContextHandler(); - } - - _handler->SetProxyOnContextInitialized(scheme, host, port); - - return this; - } - - RequestContextBuilder^ RequestContextBuilder::PersistUserPreferences() - { - ThrowExceptionIfContextAlreadySet(); - - if (_settings == nullptr) - { - _settings = gcnew RequestContextSettings(); - } - - _settings->PersistUserPreferences = true; - - return this; - } - - RequestContextBuilder^ RequestContextBuilder::WithCachePath(String^ cachePath) - { - ThrowExceptionIfContextAlreadySet(); - - if (_settings == nullptr) - { - _settings = gcnew RequestContextSettings(); - } - - _settings->CachePath = cachePath; - - return this; - } - - RequestContextBuilder^ RequestContextBuilder::WithSharedSettings(IRequestContext^ other) - { - if (other == nullptr) - { - throw gcnew ArgumentNullException("other"); - } - - ThrowExceptionIfCustomSettingSpecified(); - - _otherContext = other; - - return this; - } -} diff --git a/CefSharp.Core/RequestContextBuilder.h b/CefSharp.Core/RequestContextBuilder.h deleted file mode 100644 index 96acd18181..0000000000 --- a/CefSharp.Core/RequestContextBuilder.h +++ /dev/null @@ -1,133 +0,0 @@ -// Copyright © 2020 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "RequestContextSettings.h" - -using namespace CefSharp::Handler; - -namespace CefSharp -{ - /// - /// Fluent style builder for creating IRequestContext instances. - /// - public ref class RequestContextBuilder - { - private: - RequestContextSettings^ _settings; - IRequestContext^ _otherContext; - RequestContextHandler^ _handler; - - void ThrowExceptionIfContextAlreadySet() - { - if (_otherContext != nullptr) - { - throw gcnew Exception("A call to WithSharedSettings has already been made, it is no possible to provide custom settings."); - } - } - - void ThrowExceptionIfCustomSettingSpecified() - { - if (_settings != nullptr) - { - throw gcnew Exception("A call to WithCachePath/PersistUserPreferences has already been made, it's not possible to share settings with another RequestContext."); - } - } - - public: - /// - /// Create the actual RequestContext instance - /// - /// Returns a new RequestContext instance. - IRequestContext^ Create(); - - /// - /// Action is called in IRequestContextHandler.OnRequestContextInitialized - /// - /// called when the context has been initialized. - /// Returns RequestContextBuilder instance - RequestContextBuilder^ OnInitialize(Action^ action); - - /// - /// Sets the Cache Path - /// - /// - /// The location where cache data for this request context will be stored on - /// disk. If this value is non-empty then it must be an absolute path that is - /// either equal to or a child directory of CefSettings.RootCachePath. - /// If the value is empty then browsers will be created in "incognito mode" - /// where in-memory caches are used for storage and no data is persisted to disk. - /// HTML5 databases such as localStorage will only persist across sessions if a - /// cache path is specified. To share the global browser cache and related - /// configuration set this value to match the CefSettings.CachePath value. - /// - /// Returns RequestContextBuilder instance - RequestContextBuilder^ WithCachePath(String^ cachePath); - - /// - /// Invoke this method tp persist user preferences as a JSON file in the cache path directory. - /// Can be set globally using the CefSettings.PersistUserPreferences value. - /// This value will be ignored if CachePath is empty or if it matches the CefSettings.CachePath value. - /// - /// Returns RequestContextBuilder instance - RequestContextBuilder^ PersistUserPreferences(); - - /// - /// Set the value associated with preference name when the RequestContext - /// is initialzied. If value is null the preference will be restored to its - /// default value. If setting the preference fails no error is throw, you - /// must check the CEF Log file. - /// Preferences set via the command-line usually cannot be modified. - /// - /// preference key - /// preference value - /// Returns RequestContextBuilder instance - RequestContextBuilder^ WithPreference(String^ name, Object^ value); - - /// - /// Set the Proxy server when the RequestContext is initialzied. - /// If value is null the preference will be restored to its - /// default value. If setting the preference fails no error is throw, you - /// must check the CEF Log file. - /// Proxy set via the command-line cannot be modified. - /// - /// proxy host - /// Returns RequestContextBuilder instance - RequestContextBuilder^ WithProxyServer(String^ host); - - /// - /// Set the Proxy server when the RequestContext is initialzied. - /// If value is null the preference will be restored to its - /// default value. If setting the preference fails no error is throw, you - /// must check the CEF Log file. - /// Proxy set via the command-line cannot be modified. - /// - /// proxy host - /// proxy port (optional) - /// Returns RequestContextBuilder instance - RequestContextBuilder^ WithProxyServer(String^ host, Nullable port); - - /// - /// Set the Proxy server when the RequestContext is initialzied. - /// If value is null the preference will be restored to its - /// default value. If setting the preference fails no error is throw, you - /// must check the CEF Log file. - /// Proxy set via the command-line cannot be modified. - /// - /// proxy scheme - /// proxy host - /// proxy port (optional) - /// Returns RequestContextBuilder instance - RequestContextBuilder^ WithProxyServer(String^ scheme, String^ host, Nullable port); - - /// - /// Shares storage with other RequestContext - /// - /// shares storage with this RequestContext - /// Returns RequestContextBuilder instance - RequestContextBuilder^ WithSharedSettings(IRequestContext^ other); - }; -} - diff --git a/CefSharp.Core/RequestContextSettings.h b/CefSharp.Core/RequestContextSettings.h deleted file mode 100644 index 468b743156..0000000000 --- a/CefSharp.Core/RequestContextSettings.h +++ /dev/null @@ -1,114 +0,0 @@ -// Copyright © 2015 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" -#include "include\cef_request_context.h" - -namespace CefSharp -{ - /// - /// RequestContextSettings - /// - public ref class RequestContextSettings - { - private: - CefRequestContextSettings* _settings; - - internal: - operator CefRequestContextSettings() - { - return *_settings; - } - - public: - /// - /// Default constructor - /// - RequestContextSettings() : _settings(new CefRequestContextSettings()) - { - } - - !RequestContextSettings() - { - delete _settings; - } - - ~RequestContextSettings() - { - this->!RequestContextSettings(); - } - - /// - /// To persist session cookies (cookies without an expiry date or validity - /// interval) by default when using the global cookie manager set this value to - /// true. Session cookies are generally intended to be transient and most - /// Web browsers do not persist them. Can be set globally using the - /// CefSettings.PersistSessionCookies value. This value will be ignored if - /// CachePath is empty or if it matches the CefSettings.CachePath value. - /// - property bool PersistSessionCookies - { - bool get() { return _settings->persist_session_cookies == 1; } - void set(bool value) { _settings->persist_session_cookies = value; } - } - - /// - /// To persist user preferences as a JSON file in the cache path directory set - /// this value to true. Can be set globally using the - /// CefSettings.PersistUserPreferences value. This value will be ignored if - /// CachePath is empty or if it matches the CefSettings.CachePath value. - /// - property bool PersistUserPreferences - { - bool get() { return _settings->persist_user_preferences == 1; } - void set(bool value) { _settings->persist_user_preferences = value; } - } - - /// - /// The location where cache data for this request context will be stored on - /// disk. If this value is non-empty then it must be an absolute path that is - /// either equal to or a child directory of CefSettings.RootCachePath. - /// If the value is empty then browsers will be created in "incognito mode" - /// where in-memory caches are used for storage and no data is persisted to disk. - /// HTML5 databases such as localStorage will only persist across sessions if a - /// cache path is specified. To share the global browser cache and related - /// configuration set this value to match the CefSettings.CachePath value. - /// - property String^ CachePath - { - String^ get() { return StringUtils::ToClr(_settings->cache_path); } - void set(String^ value) { StringUtils::AssignNativeFromClr(_settings->cache_path, value); } - } - - /// - /// Comma delimited ordered list of language codes without any whitespace that - /// will be used in the "Accept-Language" HTTP header. Can be set globally - /// using the CefSettings.accept_language_list value or overridden on a per- - /// browser basis using the BrowserSettings.AcceptLanguageList value. If - /// all values are empty then "en-US,en" will be used. This value will be - /// ignored if CachePath matches the CefSettings.CachePath value. - /// - property String^ AcceptLanguageList - { - String^ get() { return StringUtils::ToClr(_settings->accept_language_list); } - void set(String^ value) { StringUtils::AssignNativeFromClr(_settings->accept_language_list, value); } - } - - /// - /// Set to true to ignore errors related to invalid SSL certificates. - /// Enabling this setting can lead to potential security vulnerabilities like - /// "man in the middle" attacks. Applications that load content from the - /// internet should not enable this setting. Can be set globally using the - /// CefSettings.IgnoreCertificateErrors value. This value will be ignored if - /// CachePath matches the CefSettings.cache_path value. - /// - property bool IgnoreCertificateErrors - { - bool get() { return _settings->ignore_certificate_errors == 1; } - void set(bool value) { _settings->ignore_certificate_errors = value; } - } - }; -} diff --git a/CefSharp.Core/UrlRequest.cpp b/CefSharp.Core/UrlRequest.cpp deleted file mode 100644 index 93fec9e1f1..0000000000 --- a/CefSharp.Core/UrlRequest.cpp +++ /dev/null @@ -1,29 +0,0 @@ -// Copyright © 2019 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#include "Stdafx.h" -#include "UrlRequest.h" -#include "Internals\CefResponseWrapper.h" - -bool UrlRequest::ResponseWasCached::get() -{ - ThrowIfDisposed(); - - return _urlRequest->ResponseWasCached(); -} - -IResponse^ UrlRequest::Response::get() -{ - ThrowIfDisposed(); - - return gcnew CefResponseWrapper(_urlRequest->GetResponse()); -} - -UrlRequestStatus UrlRequest::RequestStatus::get() -{ - ThrowIfDisposed(); - - return (UrlRequestStatus)_urlRequest->GetRequestStatus(); -} - diff --git a/CefSharp.Core/UrlRequest.h b/CefSharp.Core/UrlRequest.h deleted file mode 100644 index 79d6ccc012..0000000000 --- a/CefSharp.Core/UrlRequest.h +++ /dev/null @@ -1,96 +0,0 @@ -// Copyright © 2019 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" - -#include "include\cef_urlrequest.h" - -#include "Request.h" -#include "RequestContext.h" -#include "Internals\CefUrlRequestClientAdapter.h" -#include "Internals\CefWrapper.h" - -namespace CefSharp -{ - /// - // Class used to make a URL request. URL requests are not associated with - // a browser instance so no CefClient callbacks will be executed. - // URL requests can be created on any valid CEF thread in either the browser - // or render process. Once created the methods of the URL request object must - // be accessed on the same thread that created it. - /// - /*--cef(source=library)--*/ - public ref class UrlRequest : public IUrlRequest, public CefWrapper - { - private: - MCefRefPtr _urlRequest; - internal: - UrlRequest(CefRefPtr &urlRequest) - : _urlRequest(urlRequest) - { - } - - !UrlRequest() - { - _urlRequest = NULL; - } - - ~UrlRequest() - { - this->!UrlRequest(); - } - - public: - UrlRequest(IRequest^ request, IUrlRequestClient^ urlRequestClient) - : UrlRequest(request, urlRequestClient, nullptr) - { - } - - UrlRequest(IRequest^ request, IUrlRequestClient^ urlRequestClient, IRequestContext^ requestContext) - { - if (request == nullptr) - { - throw gcnew ArgumentNullException("request"); - } - if (urlRequestClient == nullptr) - { - throw gcnew ArgumentNullException("urlRequestClient"); - } - - _urlRequest = CefURLRequest::Create((Request^)request, new CefUrlRequestClientAdapter(urlRequestClient), (RequestContext^)requestContext); - } - - /// - // Returns true if the response body was served from the cache. This includes - // responses for which revalidation was required. - /// - /*--cef()--*/ - virtual property bool ResponseWasCached - { - bool get(); - } - - /// - // Returns the response, or NULL if no response information is available. - // Response information will only be available after the upload has completed. - // The returned object is read-only and should not be modified. - /// - /*--cef()--*/ - virtual property IResponse^ Response - { - IResponse^ get(); - } - - /// - // Returns the request status. - /// - /*--cef(default_retval=UR_UNKNOWN)--*/ - virtual property UrlRequestStatus RequestStatus - { - UrlRequestStatus get(); - } - }; -} diff --git a/CefSharp.Core/WindowInfo.h b/CefSharp.Core/WindowInfo.h deleted file mode 100644 index f155fb6dee..0000000000 --- a/CefSharp.Core/WindowInfo.h +++ /dev/null @@ -1,212 +0,0 @@ -// Copyright © 2015 The CefSharp Authors. All rights reserved. -// -// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. - -#pragma once - -#include "Stdafx.h" - -#include "include\internal\cef_win.h" - -namespace CefSharp -{ - public ref class WindowInfo : public IWindowInfo - { - private: - CefWindowInfo* _windowInfo; - bool _ownsPointer = false; - - internal: - WindowInfo(CefWindowInfo* windowInfo) : _windowInfo(windowInfo) - { - - } - - CefWindowInfo* GetWindowInfo() - { - return _windowInfo; - } - - public: - WindowInfo() : _windowInfo(new CefWindowInfo()) - { - _ownsPointer = true; - } - - !WindowInfo() - { - if (_ownsPointer) - { - delete _windowInfo; - } - - _windowInfo = NULL; - } - - ~WindowInfo() - { - this->!WindowInfo(); - } - - virtual property int X - { - int get() - { - return _windowInfo->x; - } - void set(int x) - { - _windowInfo->x = x; - } - } - - virtual property int Y - { - int get() - { - return _windowInfo->y; - } - void set(int y) - { - _windowInfo->y = y; - } - } - - virtual property int Width - { - int get() - { - return _windowInfo->width; - } - void set(int width) - { - _windowInfo->width = width; - } - } - - virtual property int Height - { - int get() - { - return _windowInfo->height; - } - void set(int height) - { - _windowInfo->height = height; - } - } - - virtual property UINT32 Style - { - UINT32 get() - { - return _windowInfo->style; - } - void set(UINT32 style) - { - _windowInfo->style = style; - } - } - - virtual property UINT32 ExStyle - { - UINT32 get() - { - return _windowInfo->ex_style; - } - void set(UINT32 ex_style) - { - _windowInfo->ex_style = ex_style; - } - } - - virtual property IntPtr ParentWindowHandle - { - IntPtr get() - { - return IntPtr(_windowInfo->parent_window); - } - void set(IntPtr parentWindowHandle) - { - _windowInfo->parent_window = (HWND)parentWindowHandle.ToPointer(); - } - } - - virtual property IntPtr WindowHandle - { - IntPtr get() - { - return IntPtr(_windowInfo->window); - } - void set(IntPtr windowHandle) - { - _windowInfo->window = (HWND)windowHandle.ToPointer(); - } - } - - virtual property bool WindowlessRenderingEnabled - { - bool get() - { - return _windowInfo->windowless_rendering_enabled == 1; - } - void set(bool windowlessRenderingEnabled) - { - _windowInfo->windowless_rendering_enabled = windowlessRenderingEnabled; - } - } - - virtual property bool SharedTextureEnabled - { - bool get() - { - return _windowInfo->shared_texture_enabled == 1; - } - void set(bool sharedTextureEnabled) - { - _windowInfo->shared_texture_enabled = sharedTextureEnabled; - } - } - - virtual property bool ExternalBeginFrameEnabled - { - bool get() - { - return _windowInfo->external_begin_frame_enabled == 1; - } - void set(bool externalBeginFrameEnabled) - { - _windowInfo->external_begin_frame_enabled = externalBeginFrameEnabled; - } - } - - virtual void SetAsChild(IntPtr parentHandle) - { - HWND hwnd = static_cast(parentHandle.ToPointer()); - RECT rect; - GetClientRect(hwnd, &rect); - CefWindowInfo window; - _windowInfo->SetAsChild(hwnd, rect); - } - - virtual void SetAsChild(IntPtr parentHandle, int left, int top, int right, int bottom) - { - RECT rect; - rect.left = left; - rect.top = top; - rect.right = right; - rect.bottom = bottom; - _windowInfo->SetAsChild((HWND)parentHandle.ToPointer(), rect); - } - - virtual void SetAsPopup(IntPtr parentHandle, String^ windowName) - { - _windowInfo->SetAsPopup((HWND)parentHandle.ToPointer(), StringUtils::ToNative(windowName)); - } - - virtual void SetAsWindowless(IntPtr parentHandle) - { - _windowInfo->SetAsWindowless((HWND)parentHandle.ToPointer()); - } - }; -} diff --git a/CefSharp.Core/packages.config b/CefSharp.Core/packages.config new file mode 100644 index 0000000000..e2934c28ce --- /dev/null +++ b/CefSharp.Core/packages.config @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/CefSharp.Example/CefSharp.Example.csproj b/CefSharp.Example/CefSharp.Example.csproj index 467e11a2da..f917b62349 100644 --- a/CefSharp.Example/CefSharp.Example.csproj +++ b/CefSharp.Example/CefSharp.Example.csproj @@ -187,8 +187,12 @@ - + {7b495581-2271-4f41-9476-acb86e8c864f} + CefSharp.Core.Runtime + + + {b760b002-d277-4525-9f63-67ed2065034a} CefSharp.Core diff --git a/CefSharp.Example/CefSharp.Example.netcore.csproj b/CefSharp.Example/CefSharp.Example.netcore.csproj index 48036ed04e..1321863df6 100644 --- a/CefSharp.Example/CefSharp.Example.netcore.csproj +++ b/CefSharp.Example/CefSharp.Example.netcore.csproj @@ -23,7 +23,7 @@ - + diff --git a/CefSharp.Example/Resources/Home.html b/CefSharp.Example/Resources/Home.html index f1838a0ad7..8fd9461bd4 100644 --- a/CefSharp.Example/Resources/Home.html +++ b/CefSharp.Example/Resources/Home.html @@ -142,7 +142,7 @@

Initialize/Shutdown Cef

} - It's important to note CEF that Initialize/Shutdown MUST be called on your main applicaiton thread (Typically the UI thead). If you call them on different + It's important to note CEF that Initialize/Shutdown MUST be called on your main application thread (typically the UI thread). If you call them on different threads, your application will hang.

diff --git a/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.csproj b/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.csproj index e7661eb9c3..19fe782b84 100644 --- a/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.csproj +++ b/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.csproj @@ -73,8 +73,12 @@ - + {7b495581-2271-4f41-9476-acb86e8c864f} + CefSharp.Core.Runtime + + + {b760b002-d277-4525-9f63-67ed2065034a} CefSharp.Core diff --git a/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.netcore.csproj b/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.netcore.csproj index 38d4f6eced..8a1e45224e 100644 --- a/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.netcore.csproj +++ b/CefSharp.OffScreen.Example/CefSharp.OffScreen.Example.netcore.csproj @@ -22,7 +22,7 @@ - + diff --git a/CefSharp.OffScreen.Example/app.manifest b/CefSharp.OffScreen.Example/app.manifest index 9006e320f7..b49c064ba6 100644 --- a/CefSharp.OffScreen.Example/app.manifest +++ b/CefSharp.OffScreen.Example/app.manifest @@ -7,7 +7,7 @@ xmlns:asmv3="urn:schemas-microsoft-com:asm.v3" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> - + diff --git a/CefSharp.OffScreen/CefSharp.OffScreen.csproj b/CefSharp.OffScreen/CefSharp.OffScreen.csproj index 4255fcbf2c..32348bae50 100644 --- a/CefSharp.OffScreen/CefSharp.OffScreen.csproj +++ b/CefSharp.OffScreen/CefSharp.OffScreen.csproj @@ -1,5 +1,6 @@ - + + @@ -17,59 +18,28 @@ 7.1 + true + true + ..\CefSharp.snk - - true - bin\x64\Debug\ - DEBUG;TRACE;OFFSCREEN - full - x64 - prompt - MinimumRecommendedRules.ruleset - bin\x64\Debug\CefSharp.OffScreen.xml - false - - - bin\x64\Release\ - TRACE;OFFSCREEN - true - pdbonly - x64 - prompt - MinimumRecommendedRules.ruleset - bin\x64\Release\CefSharp.OffScreen.xml - false - true - - + true - bin\x86\Debug\ + bin\Debug\ DEBUG;TRACE;OFFSCREEN full - x86 + AnyCPU prompt MinimumRecommendedRules.ruleset - bin\x86\Debug\CefSharp.OffScreen.xml - 1591 - false - - bin\x86\Release\ + + bin\Release\ TRACE;OFFSCREEN + bin\Release\CefSharp.OffScreen.xml true pdbonly - x86 + AnyCPU prompt MinimumRecommendedRules.ruleset - bin\x86\Release\CefSharp.OffScreen.xml - false - true - - - true - - - ..\CefSharp.snk @@ -91,8 +61,8 @@ - - {7b495581-2271-4f41-9476-acb86e8c864f} + + {b760b002-d277-4525-9f63-67ed2065034a} CefSharp.Core @@ -104,6 +74,7 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/NuGet/CefSharp.Common.app.config.x86.transform b/NuGet/CefSharp.Common.app.config.x86.transform new file mode 100644 index 0000000000..175b118681 --- /dev/null +++ b/NuGet/CefSharp.Common.app.config.x86.transform @@ -0,0 +1,27 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/NuGet/CefSharp.Common.nuspec b/NuGet/CefSharp.Common.nuspec index df8826e48c..3690fa2ed2 100644 --- a/NuGet/CefSharp.Common.nuspec +++ b/NuGet/CefSharp.Common.nuspec @@ -17,26 +17,51 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - + + + + + + + @@ -49,10 +74,13 @@ + + - - + + + diff --git a/NuGet/CefSharp.Common.props b/NuGet/CefSharp.Common.props index cfb962522c..eeb86e1c20 100644 --- a/NuGet/CefSharp.Common.props +++ b/NuGet/CefSharp.Common.props @@ -4,36 +4,11 @@ + + + - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x64\CefSharp.dll - False - - - $(MSBuildThisFileDirectory)..\CefSharp\x64\CefSharp.Core.dll - False - - - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x86\CefSharp.dll - False - - - $(MSBuildThisFileDirectory)..\CefSharp\x86\CefSharp.Core.dll - False - - - - diff --git a/NuGet/CefSharp.Common.targets b/NuGet/CefSharp.Common.targets index c15aa78fa4..c092b4648b 100644 --- a/NuGet/CefSharp.Common.targets +++ b/NuGet/CefSharp.Common.targets @@ -1,77 +1,160 @@ - - - - - + - + + + + + + + + + + + $(MSBuildExtensionsPath)\Microsoft\VisualStudio\v$(VisualStudioVersion)\Web\Microsoft.Web.Publishing.Tasks.dll + $(VSToolsPath)\Web\Microsoft.Web.Publishing.Tasks.dll + - . + . + $(CefSharpTargetDir)\x86 + $(CefSharpTargetDir)\x64 + + + + + + + + runtimes\win-x64\lib\netcoreapp3.0 + + + + + runtimes\win-x86\lib\netcoreapp3.0 + + + + + runtimes\win-x86\lib\netcoreapp3.0 + runtimes\win-x64\lib\netcoreapp3.0 + + + + + + + + - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - $(CefSharpTargetDir)\x86\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\x64\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\x86\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\x64\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - + + + + + + $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + + + + $(CefSharpTargetDirAnyCpu32)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu64)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu32)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu64)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + $(CefSharpTargetDirAnyCpu32)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu64)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + + + + + $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/NuGet/CefSharp.OffScreen.nuspec b/NuGet/CefSharp.OffScreen.nuspec index 5719d7f412..b84d48664f 100644 --- a/NuGet/CefSharp.OffScreen.nuspec +++ b/NuGet/CefSharp.OffScreen.nuspec @@ -27,18 +27,9 @@ - - - - - - - - - - - + + + diff --git a/NuGet/CefSharp.OffScreen.props b/NuGet/CefSharp.OffScreen.props deleted file mode 100644 index c532925b66..0000000000 --- a/NuGet/CefSharp.OffScreen.props +++ /dev/null @@ -1,29 +0,0 @@ - - - - - - - - - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x64\CefSharp.OffScreen.dll - False - - - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x86\CefSharp.OffScreen.dll - False - - - - - diff --git a/NuGet/CefSharp.OffScreen.targets b/NuGet/CefSharp.OffScreen.targets deleted file mode 100644 index 714a13c96a..0000000000 --- a/NuGet/CefSharp.OffScreen.targets +++ /dev/null @@ -1,53 +0,0 @@ - - - - . - - - - - - - - - - $(CefSharpTargetDir)\x86\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\x64\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - diff --git a/NuGet/CefSharp.WinForms.nuspec b/NuGet/CefSharp.WinForms.nuspec index 454b4796c6..2be89586dd 100644 --- a/NuGet/CefSharp.WinForms.nuspec +++ b/NuGet/CefSharp.WinForms.nuspec @@ -27,18 +27,9 @@ - - - - - - - - - - - + + + diff --git a/NuGet/CefSharp.WinForms.props b/NuGet/CefSharp.WinForms.props deleted file mode 100644 index 0451d0319f..0000000000 --- a/NuGet/CefSharp.WinForms.props +++ /dev/null @@ -1,29 +0,0 @@ - - - - - - - - - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x64\CefSharp.WinForms.dll - False - - - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x86\CefSharp.WinForms.dll - False - - - - - diff --git a/NuGet/CefSharp.WinForms.targets b/NuGet/CefSharp.WinForms.targets deleted file mode 100644 index 9a10ec14b1..0000000000 --- a/NuGet/CefSharp.WinForms.targets +++ /dev/null @@ -1,53 +0,0 @@ - - - - . - - - - - - - - - - $(CefSharpTargetDir)\x86\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\x64\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - diff --git a/NuGet/CefSharp.Wpf.nuspec b/NuGet/CefSharp.Wpf.nuspec index 5f230b32ed..b1fbce7f6d 100644 --- a/NuGet/CefSharp.Wpf.nuspec +++ b/NuGet/CefSharp.Wpf.nuspec @@ -27,18 +27,9 @@ - - - - - - - - - - - + + + diff --git a/NuGet/CefSharp.Wpf.props b/NuGet/CefSharp.Wpf.props deleted file mode 100644 index ea7c745140..0000000000 --- a/NuGet/CefSharp.Wpf.props +++ /dev/null @@ -1,29 +0,0 @@ - - - - - - - - - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x64\CefSharp.Wpf.dll - False - - - - - - - - $(MSBuildThisFileDirectory)..\CefSharp\x86\CefSharp.Wpf.dll - False - - - - - diff --git a/NuGet/CefSharp.Wpf.targets b/NuGet/CefSharp.Wpf.targets deleted file mode 100644 index 1e83a5650e..0000000000 --- a/NuGet/CefSharp.Wpf.targets +++ /dev/null @@ -1,53 +0,0 @@ - - - - . - - - - - - - - - - $(CefSharpTargetDir)\x86\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - $(CefSharpTargetDir)\x64\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - - - - $(CefSharpTargetDir)\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false - - - - - diff --git a/NuGet/PackageReference/CefSharp.Common.NETCore.nuspec b/NuGet/PackageReference/CefSharp.Common.NETCore.nuspec index cc9ed29227..f080228b32 100644 --- a/NuGet/PackageReference/CefSharp.Common.NETCore.nuspec +++ b/NuGet/PackageReference/CefSharp.Common.NETCore.nuspec @@ -21,7 +21,8 @@ - + + + + - - - + + + - - - + + + - - + + - - + + diff --git a/NuGet/PackageReference/CefSharp.Common.NETCore.targets b/NuGet/PackageReference/CefSharp.Common.NETCore.targets index 7eb2b0f109..92f9cb138b 100644 --- a/NuGet/PackageReference/CefSharp.Common.NETCore.targets +++ b/NuGet/PackageReference/CefSharp.Common.NETCore.targets @@ -8,12 +8,14 @@ PreserveNewest Included false + true swiftshader\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false + true @@ -24,48 +26,48 @@ PreserveNewest Included false + true swiftshader\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false + true - - + + runtimes\win-x86\native\locales\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false + true runtimes\win-x86\native\swiftshader\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false - - - runtimes\win-x86\native\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false + true runtimes\win-x86\native\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false + true runtimes\win-x86\native\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false + true @@ -73,30 +75,28 @@ PreserveNewest Included false + true runtimes\win-x64\native\swiftshader\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false - - - runtimes\win-x64\native\%(RecursiveDir)%(FileName)%(Extension) - PreserveNewest - Included - false + true runtimes\win-x64\native\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false + true runtimes\win-x64\native\%(RecursiveDir)%(FileName)%(Extension) PreserveNewest Included false + true diff --git a/build.netcore.ps1 b/build.netcore.ps1 index 16569c53b5..9368764e33 100644 --- a/build.netcore.ps1 +++ b/build.netcore.ps1 @@ -12,9 +12,9 @@ $WorkingDir = split-path -parent $MyInvocation.MyCommand.Definition $CefSln = Join-Path $WorkingDir 'CefSharp3.netcore.sln' $nuget = Join-Path $WorkingDir .\nuget\NuGet.exe -# Extract the current CEF Redist version from the CefSharp.Core\packages.CefSharp.Core.config file +# Extract the current CEF Redist version from the CefSharp.Runtime.Core\packages.CefSharp.Core.config file # Save having to update this file manually Example 3.2704.1418 -$CefSharpCorePackagesXml = [xml](Get-Content (Join-Path $WorkingDir 'CefSharp.Core\packages.CefSharp.Core.netcore.config')) +$CefSharpCorePackagesXml = [xml](Get-Content (Join-Path $WorkingDir 'CefSharp.Core.Runtime\packages.CefSharp.Core.Runtime.netcore.config')) $RedistVersion = $CefSharpCorePackagesXml.SelectSingleNode("//packages/package[@id='cef.sdk']/@version").value function Write-Diagnostic @@ -169,7 +169,7 @@ function Compile Write-Diagnostic "Restore Nuget Packages" # Restore packages - . $nuget restore CefSharp.Core\packages.CefSharp.Core.netcore.config -PackagesDirectory packages + . $nuget restore CefSharp.Core.Runtime\packages.CefSharp.Core.Runtime.netcore.config -PackagesDirectory packages . $nuget restore CefSharp.BrowserSubprocess.Core\packages.CefSharp.BrowserSubprocess.Core.netcore.config -PackagesDirectory packages &msbuild /t:restore CefSharp3.netcore.sln @@ -320,7 +320,7 @@ WriteVersionToManifest "CefSharp.WinForms.Example\app.manifest" WriteVersionToManifest "CefSharp.Wpf.Example\app.manifest" WriteVersionToResourceFile "CefSharp.BrowserSubprocess.Core\Resource.rc" -WriteVersionToResourceFile "CefSharp.Core\Resource.rc" +WriteVersionToResourceFile "CefSharp.Core.Runtime\Resource.rc" switch -Exact ($Target) { diff --git a/build.ps1 b/build.ps1 index 9a120763d8..b2714eaf18 100644 --- a/build.ps1 +++ b/build.ps1 @@ -1,5 +1,5 @@ param( - [ValidateSet("vs2015", "vs2017", "vs2019", "nupkg-only", "gitlink")] + [ValidateSet("vs2015", "vs2017", "vs2019", "nupkg-only", "genrefassemblysource")] [Parameter(Position = 0)] [string] $Target = "vs2015", [Parameter(Position = 1)] @@ -11,9 +11,9 @@ $WorkingDir = split-path -parent $MyInvocation.MyCommand.Definition $CefSln = Join-Path $WorkingDir 'CefSharp3.sln' -# Extract the current CEF Redist version from the CefSharp.Core\packages.CefSharp.Core.config file +# Extract the current CEF Redist version from the CefSharp.Core.Runtime\packages.CefSharp.Core.Runtime.config file # Save having to update this file manually Example 3.2704.1418 -$CefSharpCorePackagesXml = [xml](Get-Content (Join-Path $WorkingDir 'CefSharp.Core\packages.CefSharp.Core.config')) +$CefSharpCorePackagesXml = [xml](Get-Content (Join-Path $WorkingDir 'CefSharp.Core.Runtime\packages.CefSharp.Core.Runtime.config')) $RedistVersion = $CefSharpCorePackagesXml.SelectSingleNode("//packages/package[@id='cef.sdk']/@version").value function Write-Diagnostic @@ -312,33 +312,6 @@ function DownloadNuget() } } -function UpdateSymbolsWithGitLink() -{ - $gitlink = "GitLink.exe" - - #Check for GitLink - if ((Get-Command $gitlink -ErrorAction SilentlyContinue) -eq $null) - { - #Download if not on path and not in Nuget folder (TODO: change to different folder) - $gitlink = Join-Path $WorkingDir .\nuget\GitLink.exe - if(-not (Test-Path $gitlink)) - { - Write-Diagnostic "Downloading GitLink" - #Powershell is having problems download GitLink SSL/TLS error, force TLS 1.2 - #https://stackoverflow.com/a/55809878/4583726 - [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::TLS12 - $client = New-Object System.Net.WebClient; - $client.DownloadFile('https://github.com/GitTools/GitLink/releases/download/2.3.0/GitLink.exe', $gitlink); - } - } - - Write-Diagnostic "GitLink working dir : $WorkingDir" - - # Run GitLink in the workingDir - . $gitlink $WorkingDir -f CefSharp3.sln -u https://github.com/CefSharp/CefSharp -c Release -p x64 -ignore CefSharp.Example`,CefSharp.Wpf.Example`,CefSharp.OffScreen.Example`,CefSharp.WinForms.Example - . $gitlink $WorkingDir -f CefSharp3.sln -u https://github.com/CefSharp/CefSharp -c Release -p x86 -ignore CefSharp.Example`,CefSharp.Wpf.Example`,CefSharp.OffScreen.Example`,CefSharp.WinForms.Example -} - function WriteAssemblyVersion { param() @@ -371,6 +344,19 @@ function WriteVersionToManifest($manifest) [System.IO.File]::WriteAllLines($Filename, $NewString, $Utf8NoBomEncoding) } +function WriteVersionToTransform($transform) +{ + $Filename = Join-Path $WorkingDir $transform + $Regex = 'codeBase version="(.*?)"'; + + $TransformData = Get-Content -Encoding UTF8 $Filename + $NewString = $TransformData -replace $Regex, "codeBase version=""$AssemblyVersion.0""" + + $Utf8NoBomEncoding = New-Object System.Text.UTF8Encoding $False + [System.IO.File]::WriteAllLines($Filename, $NewString, $Utf8NoBomEncoding) +} + + function WriteVersionToResourceFile($resourceFile) { $Filename = Join-Path $WorkingDir $resourceFile @@ -417,6 +403,40 @@ function WriteVersionToAppveyor [System.IO.File]::WriteAllLines($Filename, $NewString, $Utf8NoBomEncoding) } +function GenerateRefAssemblySource +{ + $genapiVersion = '6.0.0-beta.20610.4' + $genapi = Join-Path $WorkingDir \tools\microsoft.dotnet.genapi.$genapiVersion\tools\net472\Microsoft.DotNet.GenAPI.exe + if(-not (Test-Path $genapi)) + { + $toolsFolder = Join-Path $WorkingDir \tools + $genapiNupkg = Join-Path $toolsFolder \microsoft.dotnet.genapi.$genapiVersion.nupkg + $genapiZip = Join-Path $toolsFolder \microsoft.dotnet.genapi.$genapiVersion.zip + $client = New-Object System.Net.WebClient; + #https://www.myget.org/F/cefsharp/api/v2/package/Microsoft.DotNet.GenAPI/6.0.0-beta.20610.4 + $downloadUrl = 'https://www.myget.org/F/cefsharp/api/v2/package/Microsoft.DotNet.GenAPI/' + $genapiVersion + $client.DownloadFile($downloadUrl, $genapiNupkg); + #Expand-Archive won't extract a nupkg file, simply rename to zip + Rename-Item -Path $genapiNupkg -NewName $genapiZip + + Expand-Archive -LiteralPath $genapiZip -DestinationPath (Join-Path $toolsFolder microsoft.dotnet.genapi.$genapiVersion) + } + + #.\Microsoft.DotNet.GenAPI.exe C:\projects\CefSharp\CefSharp.Core.Runtime\bin\Win32\Debug\CefSharp.Core.Runtime.dll --lang-version 7.1 --lib-path C:\projects\CefSharp\CefSharp\bin\Debug --out CefSharp.Core.Runtime.cs + + $inputDll = Join-Path $WorkingDir \CefSharp.Core.Runtime\bin\Win32\Release\CefSharp.Core.Runtime.dll + $outputFile = Join-Path $WorkingDir \CefSharp.Core.Runtime.RefAssembly\CefSharp.Core.Runtime.cs + $cefSharpDllPath = Join-Path $WorkingDir \CefSharp\bin\Release\ + $mscorlibDllPath = (Get-Item ([System.String].Assembly.Location)).Directory.ToString() + $libPath = $cefSharpDllPath + ';' + $mscorlibDllPath + + . $genapi $inputDll --lang-version 7.1 --lib-path $libPath --out $outputFile + Write-Diagnostic "Generated Ref Assembly Source $outputFile" + + #Generates slightly incorrect C#, so just manually fix it. + ((Get-Content -path $outputFile -Raw) -replace 'public sealed override void Dispose','public void Dispose') | Set-Content -Path $outputFile +} + Write-Diagnostic "CEF Redist Version = $RedistVersion" DownloadNuget @@ -432,35 +452,35 @@ WriteVersionToManifest "CefSharp.OffScreen.Example\app.manifest" WriteVersionToManifest "CefSharp.WinForms.Example\app.manifest" WriteVersionToManifest "CefSharp.Wpf.Example\app.manifest" +WriteVersionToTransform "NuGet\CefSharp.Common.app.config.x64.transform" +WriteVersionToTransform "NuGet\CefSharp.Common.app.config.x86.transform" + WriteVersionToResourceFile "CefSharp.BrowserSubprocess.Core\Resource.rc" -WriteVersionToResourceFile "CefSharp.Core\Resource.rc" +WriteVersionToResourceFile "CefSharp.Core.Runtime\Resource.rc" switch -Exact ($Target) { + "genrefassemblysource" + { + GenerateRefAssemblySource + } "nupkg-only" { Nupkg } - "gitlink" - { - UpdateSymbolsWithGitLink - } "vs2015" { VSX v140 - UpdateSymbolsWithGitLink Nupkg } "vs2017" { VSX v141 - UpdateSymbolsWithGitLink Nupkg } "vs2019" { VSX v142 - UpdateSymbolsWithGitLink Nupkg } }