mirror of
https://github.com/chromium/crashpad.git
synced 2025-01-15 10:07:56 +08:00
1aa478d161
This change was partially scripted and partially done manually with vim regex + manually placing the deleted constructors. The script change looked for destructors in the public: section of a class, if that existed the deleted constructors would go before the destructor. For manual placement I looked for any constructor in the public: section of the corresponding class. If there wasn't one, then it would ideally have gone as the first entry except below enums, classes and typedefs. This may not have been perfect, but is hopefully good enough. Fingers crossed. #include "base/macros.h" is removed from files that don't use ignore_result, which is the only other thing defined in base/macros.h. Bug: chromium:1010217 Change-Id: I099526255a40b1ac1264904b4ece2f3f503c9418 Reviewed-on: https://chromium-review.googlesource.com/c/crashpad/crashpad/+/3171034 Reviewed-by: Mark Mentovai <mark@chromium.org> Commit-Queue: Peter Boström <pbos@chromium.org>
151 lines
5.6 KiB
C++
151 lines
5.6 KiB
C++
// Copyright 2015 The Crashpad Authors. All rights reserved.
|
||
//
|
||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||
// you may not use this file except in compliance with the License.
|
||
// You may obtain a copy of the License at
|
||
//
|
||
// http://www.apache.org/licenses/LICENSE-2.0
|
||
//
|
||
// Unless required by applicable law or agreed to in writing, software
|
||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
// See the License for the specific language governing permissions and
|
||
// limitations under the License.
|
||
|
||
#ifndef CRASHPAD_UTIL_NUMERIC_CHECKED_ADDRESS_RANGE_H_
|
||
#define CRASHPAD_UTIL_NUMERIC_CHECKED_ADDRESS_RANGE_H_
|
||
|
||
#include <stdint.h>
|
||
|
||
#include <string>
|
||
|
||
#include "build/build_config.h"
|
||
#include "util/numeric/checked_range.h"
|
||
|
||
namespace crashpad {
|
||
namespace internal {
|
||
|
||
//! \brief Ensures that a range, composed of a base and a size, does not
|
||
//! overflow the pointer type of the process it describes a range in.
|
||
//!
|
||
//! This class checks bases of type `ValueType` and sizes of type `SizeType`
|
||
//! against a process whose pointer type is either 32 or 64 bits wide.
|
||
//!
|
||
//! Aside from varying the overall range on the basis of a process’ pointer type
|
||
//! width, this class functions very similarly to CheckedRange.
|
||
//!
|
||
//! \sa CheckedMachAddressRange
|
||
template <class ValueType, class SizeType>
|
||
class CheckedAddressRangeGeneric {
|
||
public:
|
||
//! \brief Initializes a default range.
|
||
//!
|
||
//! The default range has base 0, size 0, and appears to be from a 32-bit
|
||
//! process.
|
||
CheckedAddressRangeGeneric();
|
||
|
||
//! \brief Initializes a range.
|
||
//!
|
||
//! See SetRange().
|
||
CheckedAddressRangeGeneric(bool is_64_bit, ValueType base, SizeType size);
|
||
|
||
//! \brief Sets a range’s fields.
|
||
//!
|
||
//! \param[in] is_64_bit `true` if \a base and \a size refer to addresses in a
|
||
//! 64-bit process; `false` if they refer to addresses in a 32-bit
|
||
//! process.
|
||
//! \param[in] base The range’s base address.
|
||
//! \param[in] size The range’s size.
|
||
void SetRange(bool is_64_bit, ValueType base, SizeType size);
|
||
|
||
//! \brief The range’s base address.
|
||
ValueType Base() const;
|
||
|
||
//! \brief The range’s size.
|
||
SizeType Size() const;
|
||
|
||
//! \brief The range’s end address (its base address plus its size).
|
||
ValueType End() const;
|
||
|
||
//! \brief Returns the validity of the address range.
|
||
//!
|
||
//! \return `true` if the address range is valid, `false` otherwise.
|
||
//!
|
||
//! An address range is valid if its size can be converted to the address
|
||
//! range’s data type without data loss, and if its end (base plus size) can
|
||
//! be computed without overflowing its data type.
|
||
bool IsValid() const;
|
||
|
||
//! \brief Returns whether this range refers to a 64-bit process.
|
||
bool Is64Bit() const { return is_64_bit_; }
|
||
|
||
//! \brief Returns whether the address range contains another address.
|
||
//!
|
||
//! \param[in] value The (possibly) contained address.
|
||
//!
|
||
//! \return `true` if the address range contains \a value, `false` otherwise.
|
||
//!
|
||
//! An address range contains a value if the value is greater than or equal to
|
||
//! its base address, and less than its end address (base address plus size).
|
||
//!
|
||
//! This method must only be called if IsValid() would return `true`.
|
||
bool ContainsValue(const ValueType value) const;
|
||
|
||
//! \brief Returns whether the address range contains another address range.
|
||
//!
|
||
//! \param[in] that The (possibly) contained address range.
|
||
//!
|
||
//! \return `true` if `this` address range, the containing address range,
|
||
//! contains \a that, the contained address range. `false` otherwise.
|
||
//!
|
||
//! An address range contains another address range when the contained address
|
||
//! range’s base is greater than or equal to the containing address range’s
|
||
//! base, and the contained address range’s end is less than or equal to the
|
||
//! containing address range’s end.
|
||
//!
|
||
//! This method should only be called on two CheckedAddressRangeGeneric
|
||
//! objects representing address ranges in the same process.
|
||
//!
|
||
//! This method must only be called if IsValid() would return `true` for both
|
||
//! CheckedAddressRangeGeneric objects involved.
|
||
bool ContainsRange(const CheckedAddressRangeGeneric& that) const;
|
||
|
||
//! \brief Returns a string describing the address range.
|
||
//!
|
||
//! The string will be formatted as `"0x123 + 0x45 (64)"`, where the
|
||
//! individual components are the address, size, and bitness.
|
||
std::string AsString() const;
|
||
|
||
private:
|
||
#if defined(COMPILER_MSVC)
|
||
// MSVC cannot handle a union containing CheckedRange (with constructor, etc.)
|
||
// currently.
|
||
CheckedRange<uint32_t> range_32_;
|
||
CheckedRange<uint64_t> range_64_;
|
||
#else
|
||
// The field of the union that is expressed is determined by is_64_bit_.
|
||
union {
|
||
CheckedRange<uint32_t> range_32_;
|
||
CheckedRange<uint64_t> range_64_;
|
||
};
|
||
#endif
|
||
|
||
// Determines which field of the union is expressed.
|
||
bool is_64_bit_;
|
||
|
||
// Whether the base and size were valid for their data type when set. This is
|
||
// always true when is_64_bit_ is true because the underlying data types are
|
||
// 64 bits wide and there is no possibility for range and size to overflow.
|
||
// When is_64_bit_ is false, range_ok_ will be false if SetRange() was passed
|
||
// a base or size that overflowed the underlying 32-bit data type. This field
|
||
// is necessary because the interface exposes the address and size types
|
||
// uniformly, but these types are too wide for the underlying pointer and size
|
||
// types in 32-bit processes.
|
||
bool range_ok_;
|
||
};
|
||
|
||
} // namespace internal
|
||
} // namespace crashpad
|
||
|
||
#endif // CRASHPAD_UTIL_NUMERIC_CHECKED_ADDRESS_RANGE_H_
|