mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 13:23:07 +00:00
5ec13acbdd
- Bug 1140264 part 1 - Avoid expanding auto-hidden ruby annotations. r=dbaron (5b6ddba10) - Bug 1140264 part 2 - Move and merge line breaking code in rbc reflow to reduce useless computation and fix undesired break point. r=dbaron (0d3aaad79) - Bug 1140264 part 3 - Rename IsInlineDescendantOfRuby to ShouldSuppressLineBreak and exclude rbc/rtc from it. r=dbaron (e929b296b) - Bug 1140264 part 4 - Reftest for this bug. r=dbaron (3aa19d44e) - Bug 1141842 - Add LastOptionalBreakPriority to nsLineLayout to simplify some code. r=roc (81cc1dcd0) - Bug 1137875 - Have the SharedFrameMetricsData hold a copy of the layers id. r=nical (81c657510) - Bug 1133237 - When transitioning from a shadow layer tree that has plugins to a tree that does not, make sure the old plugins get hidden properly. r=roc (11ff16c17) - Bug 1137875 - Have the LayerTransactionChild hold a copy of the layers id. r=nical (f9a090aad) - Bug 1137875 - Clear shared frame metrics objects associated with a PLayerTransaction when it is destroyed. r=nical (c5037ee27) - Bug 1119878 Part 1: Change SandboxTarget to hold sandbox target services to provide functions. r=aklotz, r=glandium, r=cpearce (7378d13e4) - Bug 1119878 Part 2: Change IPC code to hold ProcessID instead of ProcessHandle. r=billm, r=dvander, r=aklotz, r=cpearce (fa002f559) - Bug 1149971 Part 1: Follow-up to bug 1119878 to fix broken IPDL tests. r=dvander (76b843d43) and some lines of fix of toolkit/xre/nsEmbedFunctions.cpp after Bug 1119878 Part 2.
77 lines
1.9 KiB
C++
77 lines
1.9 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include <windows.h>
|
|
|
|
#include "base/process_util.h"
|
|
#include "CrossProcessMutex.h"
|
|
#include "nsDebug.h"
|
|
#include "nsISupportsImpl.h"
|
|
#include "ProtocolUtils.h"
|
|
|
|
using base::GetCurrentProcessHandle;
|
|
using base::ProcessHandle;
|
|
|
|
namespace mozilla {
|
|
|
|
CrossProcessMutex::CrossProcessMutex(const char*)
|
|
{
|
|
// We explicitly share this using DuplicateHandle, we do -not- want this to
|
|
// be inherited by child processes by default! So no security attributes are
|
|
// given.
|
|
mMutex = ::CreateMutexA(nullptr, FALSE, nullptr);
|
|
if (!mMutex) {
|
|
NS_RUNTIMEABORT("This shouldn't happen - failed to create mutex!");
|
|
}
|
|
MOZ_COUNT_CTOR(CrossProcessMutex);
|
|
}
|
|
|
|
CrossProcessMutex::CrossProcessMutex(CrossProcessMutexHandle aHandle)
|
|
{
|
|
DWORD flags;
|
|
if (!::GetHandleInformation(aHandle, &flags)) {
|
|
NS_RUNTIMEABORT("Attempt to construct a mutex from an invalid handle!");
|
|
}
|
|
mMutex = aHandle;
|
|
MOZ_COUNT_CTOR(CrossProcessMutex);
|
|
}
|
|
|
|
CrossProcessMutex::~CrossProcessMutex()
|
|
{
|
|
NS_ASSERTION(mMutex, "Improper construction of mutex or double free.");
|
|
::CloseHandle(mMutex);
|
|
MOZ_COUNT_DTOR(CrossProcessMutex);
|
|
}
|
|
|
|
void
|
|
CrossProcessMutex::Lock()
|
|
{
|
|
NS_ASSERTION(mMutex, "Improper construction of mutex.");
|
|
::WaitForSingleObject(mMutex, INFINITE);
|
|
}
|
|
|
|
void
|
|
CrossProcessMutex::Unlock()
|
|
{
|
|
NS_ASSERTION(mMutex, "Improper construction of mutex.");
|
|
::ReleaseMutex(mMutex);
|
|
}
|
|
|
|
CrossProcessMutexHandle
|
|
CrossProcessMutex::ShareToProcess(base::ProcessId aTargetPid)
|
|
{
|
|
HANDLE newHandle;
|
|
bool succeeded = ipc::DuplicateHandle(mMutex, aTargetPid, &newHandle,
|
|
0, DUPLICATE_SAME_ACCESS);
|
|
|
|
if (!succeeded) {
|
|
return nullptr;
|
|
}
|
|
|
|
return newHandle;
|
|
}
|
|
|
|
}
|