This file is indexed.

/usr/include/falcon/cacheobject.h is in falconpl-dev 0.9.6.9-git20120606-2.

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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/*
   FALCON - The Falcon Programming Language.
   FILE: cacheobject.h

   Falcon Object - Standard instance of classes in script
   -------------------------------------------------------------------
   Author: Giancarlo Niccolai
   Begin: Sat, 24 Jan 2009 13:48:11 +0100

   -------------------------------------------------------------------
   (C) Copyright 2009: the FALCON developers (see list in AUTHORS file)

   See LICENSE file for licensing details.
*/

/** \file
   Falcon Object - Standard instance of classes in script
*/

#ifndef FLC_CACHE_OBJECT_H
#define FLC_CACHE_OBJECT_H

#include <falcon/setup.h>
#include <falcon/coreobject.h>
#include <falcon/cclass.h>

namespace Falcon
{

class VMachine;

class FALCON_DYN_CLASS CacheObject: public CoreObject
{
protected:
   mutable Item *m_cache;

   CacheObject( const CoreClass* generator, bool bSeralizing = false );
   CacheObject( const CacheObject &other );

public:

   virtual ~CacheObject();

   virtual bool serialize( Stream *stream, bool bLive ) const;
   virtual bool deserialize( Stream *stream, bool bLive );
   virtual bool setProperty( const String &prop, const Item &value );
   virtual bool getProperty( const String &key, Item &ret ) const;

   /** Mark the items in the cache and the inner data, if it's garbageable.
      If this object contains an external FalconData instance, it gets marked;
      anyhow, this function marks the cache items.
   */
   virtual void gcMark( uint32 mark );

   Item *cachedProperty( const String &name ) const
   {
      register uint32 pos;
      if ( ! m_generatedBy->properties().findKey( name, pos ) )
         return 0;

      return m_cache + pos;
   }

   Item *cachedPropertyAt( uint32 pos ) const {
      if ( pos > m_generatedBy->properties().added() )
         return 0;
      return m_cache + pos;
   }

   /** Reflect an external data into this object.
      This method uses the reflection informations in the generator class property table
      to load the data stored in the user_data parameter into the local item vector cache.

      As this is an optional operation, the base class implementation does nothing.
   */
   virtual void reflectFrom( void *user_data );

   /** Reflect this object into external data.

      This method uses the reflection informations in the generator class property table
      to store a C/C++ copy of the data stored in the local cache of this object into
      an external data.

      As this is an optional operation, the base class implementation does nothing.
   */
   virtual void reflectTo( void *user_data ) const;

};

}

#endif

/* end of cacheobject.h */