security/sandbox/chromium/base/callback_internal.cc

Tue, 06 Jan 2015 21:39:09 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Tue, 06 Jan 2015 21:39:09 +0100
branch
TOR_BUG_9701
changeset 8
97036ab72558
permissions
-rw-r--r--

Conditionally force memory storage according to privacy.thirdparty.isolate;
This solves Tor bug #9701, complying with disk avoidance documented in
https://www.torproject.org/projects/torbrowser/design/#disk-avoidance.

     1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
     2 // Use of this source code is governed by a BSD-style license that can be
     3 // found in the LICENSE file.
     5 #include "base/callback_internal.h"
     7 #include "base/logging.h"
     9 namespace base {
    10 namespace internal {
    12 bool CallbackBase::is_null() const {
    13   return bind_state_.get() == NULL;
    14 }
    16 void CallbackBase::Reset() {
    17   polymorphic_invoke_ = NULL;
    18   // NULL the bind_state_ last, since it may be holding the last ref to whatever
    19   // object owns us, and we may be deleted after that.
    20   bind_state_ = NULL;
    21 }
    23 bool CallbackBase::Equals(const CallbackBase& other) const {
    24   return bind_state_.get() == other.bind_state_.get() &&
    25          polymorphic_invoke_ == other.polymorphic_invoke_;
    26 }
    28 CallbackBase::CallbackBase(BindStateBase* bind_state)
    29     : bind_state_(bind_state),
    30       polymorphic_invoke_(NULL) {
    31   DCHECK(!bind_state_.get() || bind_state_->HasOneRef());
    32 }
    34 CallbackBase::~CallbackBase() {
    35 }
    37 }  // namespace internal
    38 }  // namespace base

mercurial