LCOV - code coverage report
Current view: top level - mfbt - RangedArray.h (source / functions) Hit Total Coverage
Test: output.info Lines: 7 7 100.0 %
Date: 2017-07-14 16:53:18 Functions: 10 16 62.5 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
       2             : /* vim: set ts=8 sts=2 et sw=2 tw=80: */
       3             : /* This Source Code Form is subject to the terms of the Mozilla Public
       4             :  * License, v. 2.0. If a copy of the MPL was not distributed with this
       5             :  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
       6             : 
       7             : /*
       8             :  * A compile-time constant-length array, with bounds-checking assertions -- but
       9             :  * unlike mozilla::Array, with indexes biased by a constant.
      10             :  *
      11             :  * Thus where mozilla::Array<int, 3> is a three-element array indexed by [0, 3),
      12             :  * mozilla::RangedArray<int, 8, 3> is a three-element array indexed by [8, 11).
      13             :  */
      14             : 
      15             : #ifndef mozilla_RangedArray_h
      16             : #define mozilla_RangedArray_h
      17             : 
      18             : #include "mozilla/Array.h"
      19             : 
      20             : namespace mozilla {
      21             : 
      22             : template<typename T, size_t MinIndex, size_t Length>
      23        4397 : class RangedArray
      24             : {
      25             : private:
      26             :   typedef Array<T, Length> ArrayType;
      27             :   ArrayType mArr;
      28             : 
      29             : public:
      30      579474 :   T& operator[](size_t aIndex)
      31             :   {
      32      579474 :     MOZ_ASSERT(aIndex == MinIndex || aIndex > MinIndex);
      33      579474 :     return mArr[aIndex - MinIndex];
      34             :   }
      35             : 
      36      304401 :   const T& operator[](size_t aIndex) const
      37             :   {
      38      304401 :     MOZ_ASSERT(aIndex == MinIndex || aIndex > MinIndex);
      39      304401 :     return mArr[aIndex - MinIndex];
      40             :   }
      41             : 
      42             :   typedef typename ArrayType::iterator               iterator;
      43             :   typedef typename ArrayType::const_iterator         const_iterator;
      44             :   typedef typename ArrayType::reverse_iterator       reverse_iterator;
      45             :   typedef typename ArrayType::const_reverse_iterator const_reverse_iterator;
      46             : 
      47             :   // Methods for range-based for loops.
      48             :   iterator begin() { return mArr.begin(); }
      49             :   const_iterator begin() const { return mArr.begin(); }
      50             :   const_iterator cbegin() const { return mArr.cbegin(); }
      51             :   iterator end() { return mArr.end(); }
      52             :   const_iterator end() const { return mArr.end(); }
      53             :   const_iterator cend() const { return mArr.cend(); }
      54             : 
      55             :   // Methods for reverse iterating.
      56             :   reverse_iterator rbegin() { return mArr.rbegin(); }
      57             :   const_reverse_iterator rbegin() const { return mArr.rbegin(); }
      58             :   const_reverse_iterator crbegin() const { return mArr.crbegin(); }
      59             :   reverse_iterator rend() { return mArr.rend(); }
      60             :   const_reverse_iterator rend() const { return mArr.rend(); }
      61             :   const_reverse_iterator crend() const { return mArr.crend(); }
      62             : };
      63             : 
      64             : } // namespace mozilla
      65             : 
      66             : #endif // mozilla_RangedArray_h

Generated by: LCOV version 1.13