This file is indexed.

/usr/include/ossim/base/ossimFactoryBaseTemplate.h is in libossim-dev 2.2.2-1.

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
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
//*******************************************************************
//
// License:  See top level LICENSE.txt file.
//
// DESCRIPTION:
//   Contains declaration of template class ossimFactory. This is the base
//   type for all factories.
//
// SOFTWARE HISTORY:
//>
//   14Jun2001  Oscar Kramer (okramer@imagelinks.com)
//              Initial coding.
//<
//*****************************************************************************
//  $Id: ossimFactoryBaseTemplate.h 14799 2009-06-30 08:54:44Z dburken $

#ifndef ossimFactory_HEADER
#define ossimFactory_HEADER
#include <ossim/base/ossimConstants.h>
#include <list>

class ossimKeywordlist;
class ossimString;

/*!****************************************************************************
 *
 * TEMPLATE: ossimFactoryBase  
 *
 * NOTE: This is primarily intended as an interface template only to insure
 *       that all factories prescribe to a common type. Concrete classes shall
 *       be derived from an instance of this template as:
 *
 *       class MyFactory : public ossimFactoryBase<MyProductClass>
 *
 *       where MyProductClass is the class type being produced.
 *
 *       This template is applicable to "Registry" type factories that have
 *       one or more sub-factories. Thus, a common interface is provided
 *       without the client distinguishing between registries and factories.
 *
 * EXAMPLE: Refer to the projection factories for a working example of the
 *       use of this base class template. Specifically, refer to the files:
 *          - ../ossim_core/projections/factory/ossimProjectionFactory.h
 *          - ../ossim_core/projections/factory/ossimMapProjectionFactory.h
 *          - ../ossim_core/projections/factory/ossimSensorModelFactory.h
 *
 *****************************************************************************/
template <class Product> class OSSIMDLLEXPORT ossimFactoryBase 
{
public:
   /*!
    * METHOD: instance()
    * For accessing static singleton instance of concrete factory. The derived
    * class implementation of this method invokes the factory's private
    * constructor. MUST BE PROVIDED BY CONCRETE DERIVED CLASS as follows:
    *
    static <ossimFactoryBase-derived class>* instance();
    */
   
   /*!
    * PURE VIRTUAL METHODS: create(string), create(keywordlist, prefix)
    *
    * Attempts to create an instance of the Product given a string or
    * keywordlist. It is up to the concrete factory implementation to decide
    * how to interpret string. It could conceivably represent a "magic
    * number" specification of a product (such as the class name). Or, it could
    * be a filename that the factory must open to decide which product
    * to instantiate. The derived factory can also define other create methods
    * following the model used here.
    *
    * Returns successfully constructed product or NULL.
    */
   virtual Product* create(const ossimString&)     const = 0;
   virtual Product* create(const ossimKeywordlist& kwl,
                           const char* prefix)          const = 0;

   /*!
    * PURE VIRTUAL METHOD: getList()
    * Returns name list of all products represented by this factory:
    */
   virtual std::list<ossimString> getList() const = 0;

   /*!
    * METHOD: registerFactory()
    * Adds sub-factories to this one. Relevant for the case where the
    * derived factory maintains a registry of sub-factories.
    */
   void registerFactory(ossimFactoryBase<Product>* new_factory)
      { if(new_factory) theRegistry.push_back(new_factory); }
   
protected:
   /*!
    * PROTECTED DEFAULT CONSTRUCTOR
    * Gives concrete class the opportunity to perform initialization
    * tasks since this is called once with first instance() call. If the
    * derived factory is to serve as a sub-factory registry, then have the
    * derived class' constructor call registerFactory() for all of the default
    * sub-factories involved.
    */
   ossimFactoryBase() {};

   virtual ~ossimFactoryBase() {}

   /*!
    * Member contains list of sub-factories associated with this factory:
    */
   std::list<ossimFactoryBase<Product>*> theRegistry;
   
};

#endif