This file is indexed.

/usr/include/crystalspace-2.0/csutil/scopedpointer.h is in libcrystalspace-dev 2.0+dfsg-1build1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/*
  Copyright (C) 2007-2011 by Frank Richter

  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Library General Public
  License as published by the Free Software Foundation; either
  version 2 of the License, or (at your option) any later version.

  This library is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  Library General Public License for more details.

  You should have received a copy of the GNU Library General Public
  License along with this library; if not, write to the Free
  Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#ifndef __CSUTIL_SCOPEDPOINTER_H__
#define __CSUTIL_SCOPEDPOINTER_H__

/**\file
 * Pointer valid in a scope
 */

#include "csutil/noncopyable.h"

namespace CS
{
namespace Utility
{

  /**
   * Smart pointer that deletes the contained pointer when the scope is exited.
   * \tparam T is the type pointed to.
   */
  template<class T>
  class ScopedPointer : private NonCopyable
  {
    T* ptr;
  public:
    /**
     * Construct from given pointer.
     * \remarks Takes ownership of \a ptr!
     */
    ScopedPointer (T* ptr = nullptr) : ptr (ptr) {}
    /// Destruct. Deletes the given pointer!
    ~ScopedPointer() { delete ptr; }

    /**
     * Replace the contained pointer with another.
     * \remarks Takes ownership of \a ptr!
     */
    void Reset (T* ptr = nullptr)
    {
      delete this->ptr;
      this->ptr = ptr;
    }
    /// Invalidate (delete) the contained pointer
    void Invalidate() { Reset(); }
    /// Check if the contained pointer is valid.
    bool IsValid() const { return ptr != (T*)nullptr; }
  
    /// Dereference underlying pointer.
    T* operator -> () const
    { return ptr; }
    
    /// Cast to a pointer.
    operator T* () const
    { return ptr; }
    
    /// Dereference underlying pointer.
    T& operator* () const
    { return *ptr; }
  
  };

} // namespace Utility
} // namespace CS

#endif // __CSUTIL_SCOPEDPOINTER_H__