* chore: bump chromium in DEPS to 103.0.5020.0 * chore: bump chromium in DEPS to 103.0.5022.0 * chore: bump chromium in DEPS to 103.0.5024.0 * chore: update patches * 3587410: [Printing] Remove JobEventDetails Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3587410 * chore: bump chromium in DEPS to 103.0.5026.0 * chore: update patches * 3577218: WebUI: Delete webui_resources.grd and related GN targets. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3577218 * chore: bump chromium in DEPS to 103.0.5028.0 * chore: update patches * 3579297: Convert UpdatePrintSettings() to use non-deprecated base::Value APIs. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3579297 * 3560622: serial: Add SerialPort.forget() method Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3560622 * 3581708: Restore original display when moving from tab-fullscreen to browser-fullscreen. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3581708 * chore: fix authorization flags lint error * 3583363: Remove net wrappers around base/strings/escape.h Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3583363 * fixup! 3560622: serial: Add SerialPort.forget() method Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3560622 * 3587589: Reland "Propagate the MIME type from DownloadTargetDeterminer to DownloadItem" Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3587589 * 3584006: Remove IsRenderViewLive from content public Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3584006 * 3596174: [api] Remove APIs for resurrecting finalizers Ref: https://chromium-review.googlesource.com/c/v8/v8/+/3596174 * 3368244: Hook SnapshotForContentAnalysis renderer API to scan system prints Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3368244 * chore: bump chromium in DEPS to 103.0.5030.0 * chore: update patches * chore: bump chromium in DEPS to 103.0.5032.0 * chore: bump chromium in DEPS to 103.0.5034.0 * chore: bump chromium in DEPS to 103.0.5036.0 * chore: update patches * 3586363: Introduce PrintRenderFrame.PrintWithParams() for batch printing to PDF Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3586363 * 3593199: Remove content::PermissionType references and replace them with blink::PermissionType Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3593199 * 3368244: Hook SnapshotForContentAnalysis renderer API to scan system prints Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3368244 * chore: lint * chore: bump chromium in DEPS to 103.0.5038.0 * chore: update patches * fixup! 3560622: serial: Add SerialPort.forget() method * 3606495: mac screen capture: add metric Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3606495 * chore: bump chromium in DEPS to 103.0.5040.0 * chore: update patches * 3590840: Add IPs to DnsOverHttpsServerConfig https://chromium-review.googlesource.com/c/chromium/src/+/3590840 * stub functions for ElectronSerialDelegate and SerialChooserController to fix link * 3566412: [base] Remove base/android dependency on post_task.h and officially remove post_task.h! Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3566412 * 3347944: [content] No longer hand-off whole MainFunctionParams to BrowserMainParts Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3347944 * fixup! 3566412: [base] Remove base/android dependency on post_task.h and off… e3ea3e1 …icially remove post_task.h! * chore: update process_singleton patches for content::GetIOThreadTaskRunner({}) Ref: 2015655: [BrowserThread] Migrate co/pub/br and co/br/scheduler to the new API | https://chromium-review.googlesource.com/c/chromium/src/+/2015655 * chore: migrate base::DeleteSoon to content::GetUIThreadTaskRunner({})->DeleteSoon Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3566412 * chore: remove duplicate functions for RevokePortPermissionWebInitiated & GetPortInfo * chore: migrate Linux/Windows methods off of post_task.h Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3566412 * 64908: Stop building legacy SwiftShader GL in Chromium https://swiftshader-review.googlesource.com/c/SwiftShader/+/64908 * 3573245: Added Themed versions of RoundedRectBackground and RoundedRectBorder. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3573245 * chore: bump chromium in DEPS to 103.0.5042.0 * chore: update patches * 3571804: [api] Advance API deprecation for V8 version v10.2 https://chromium-review.googlesource.com/c/v8/v8/+/3571804 * fixup! 3571804: [api] Advance API deprecation for V8 version v10.2 * build: fix run-clang-format extension matching * lint * fix windows build * how is clang-format still not working for me * chore: update patches * 3623985: Replace ad-hoc SetPublicFirstPartySets calls with method in ContentBrowserClient. https://chromium-review.googlesource.com/c/chromium/src/+/3623985 * no need to implement WillProvidePublicFirstPartySets; the default is false * 3601036: [QT] Introduce ui/views/linux_ui/linux_ui_factory.* https://chromium-review.googlesource.com/c/chromium/src/+/3601036 * 3583363: Remove net wrappers around base/strings/escape.h https://chromium-review.googlesource.com/c/chromium/src/+/3583363 * lint * chore: bump chromium in DEPS to 103.0.5044.0 * fix conflicts * chore: update patches * upgrade nan * pin version of nan in tests * replace my hacky deprecated override fix with the fix from upstream * revert runtime dcheck in v8 * pin nan version at root too * refactor: tell gyp to use c++17 when building with our node * Revert "refactor: tell gyp to use c++17 when building with our node" This reverts commit 41a03a5799a8f40f31555d73d20ea865acfcd192. * Undo the reversion of 41a03a5799a8f40f31555d73d20ea865acfcd192. This reverts commit 54440abc598153bd7e259be4a908f0ecc0b33348. * disable sequential/test-cpu-prof-kill for now * also sequential/test-diagnostic-dir-cpu-prof Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Keeley Hammond <khammond@slack-corp.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: VerteDinde <vertedinde@electronjs.org> Co-authored-by: Jeremy Rose <japthorp@slack-corp.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Jeremy Rose <jeremya@chromium.org> Co-authored-by: Charles Kerr <charles@charleskerr.com>
		
			
				
	
	
		
			80 lines
		
	
	
	
		
			2.6 KiB
			
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
	
		
			2.6 KiB
			
		
	
	
	
		
			C++
		
	
	
	
	
	
// Copyright (c) 2020 The Chromium 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 ELECTRON_SHELL_BROWSER_UI_WIN_DIALOG_THREAD_H_
 | 
						|
#define ELECTRON_SHELL_BROWSER_UI_WIN_DIALOG_THREAD_H_
 | 
						|
 | 
						|
#include <utility>
 | 
						|
 | 
						|
#include "base/memory/scoped_refptr.h"
 | 
						|
#include "content/public/browser/browser_task_traits.h"
 | 
						|
#include "content/public/browser/browser_thread.h"
 | 
						|
 | 
						|
namespace dialog_thread {
 | 
						|
 | 
						|
// Returns the dedicated single-threaded sequence that the dialog will be on.
 | 
						|
using TaskRunner = scoped_refptr<base::SingleThreadTaskRunner>;
 | 
						|
TaskRunner CreateDialogTaskRunner();
 | 
						|
 | 
						|
// Runs the |execute| in dialog thread and pass result to |done| in UI thread.
 | 
						|
template <typename R>
 | 
						|
void Run(base::OnceCallback<R()> execute, base::OnceCallback<void(R)> done) {
 | 
						|
  // dialogThread.postTask(() => {
 | 
						|
  //   r = execute()
 | 
						|
  //   uiThread.postTask(() => {
 | 
						|
  //     done(r)
 | 
						|
  //   }
 | 
						|
  // })
 | 
						|
  TaskRunner task_runner = CreateDialogTaskRunner();
 | 
						|
  task_runner->PostTask(
 | 
						|
      FROM_HERE,
 | 
						|
      base::BindOnce(
 | 
						|
          [](TaskRunner task_runner, base::OnceCallback<R()> execute,
 | 
						|
             base::OnceCallback<void(R)> done) {
 | 
						|
            R r = std::move(execute).Run();
 | 
						|
            content::GetUIThreadTaskRunner({})->PostTask(
 | 
						|
                FROM_HERE,
 | 
						|
                base::BindOnce(
 | 
						|
                    [](TaskRunner task_runner, base::OnceCallback<void(R)> done,
 | 
						|
                       R r) {
 | 
						|
                      std::move(done).Run(std::move(r));
 | 
						|
                      // Task runner will destroyed automatically after the
 | 
						|
                      // scope ends.
 | 
						|
                    },
 | 
						|
                    std::move(task_runner), std::move(done), std::move(r)));
 | 
						|
          },
 | 
						|
          std::move(task_runner), std::move(execute), std::move(done)));
 | 
						|
}
 | 
						|
 | 
						|
// Adaptor to handle the |execute| that returns bool.
 | 
						|
template <typename R>
 | 
						|
void Run(base::OnceCallback<bool(R*)> execute,
 | 
						|
         base::OnceCallback<void(bool, R)> done) {
 | 
						|
  // run(() => {
 | 
						|
  //   result = execute(&value)
 | 
						|
  //   return {result, value}
 | 
						|
  // }, ({result, value}) => {
 | 
						|
  //   done(result, value)
 | 
						|
  // })
 | 
						|
  struct Result {
 | 
						|
    bool result;
 | 
						|
    R value;
 | 
						|
  };
 | 
						|
  Run(base::BindOnce(
 | 
						|
          [](base::OnceCallback<bool(R*)> execute) {
 | 
						|
            Result r;
 | 
						|
            r.result = std::move(execute).Run(&r.value);
 | 
						|
            return r;
 | 
						|
          },
 | 
						|
          std::move(execute)),
 | 
						|
      base::BindOnce(
 | 
						|
          [](base::OnceCallback<void(bool, R)> done, Result r) {
 | 
						|
            std::move(done).Run(r.result, std::move(r.value));
 | 
						|
          },
 | 
						|
          std::move(done)));
 | 
						|
}
 | 
						|
 | 
						|
}  // namespace dialog_thread
 | 
						|
 | 
						|
#endif  // ELECTRON_SHELL_BROWSER_UI_WIN_DIALOG_THREAD_H_
 |