This file is indexed.

/usr/include/d/gtkd-3/atk/Registry.d is in libgtkd-3-dev 3.7.5-2build1.

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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
/*
 * This file is part of gtkD.
 *
 * gtkD is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License
 * as published by the Free Software Foundation; either version 3
 * of the License, or (at your option) any later version, with
 * some exceptions, please read the COPYING file.
 *
 * gtkD 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 Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with gtkD; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
 */

// generated automatically - do not change
// find conversion definition on APILookup.txt
// implement new conversion functionalities on the wrap.utils pakage


module atk.Registry;

private import atk.ObjectFactory;
private import atk.c.functions;
public  import atk.c.types;
private import gobject.ObjectG;
public  import gtkc.atktypes;


/**
 * The AtkRegistry is normally used to create appropriate ATK "peers"
 * for user interface components.  Application developers usually need
 * only interact with the AtkRegistry by associating appropriate ATK
 * implementation classes with GObject classes via the
 * atk_registry_set_factory_type call, passing the appropriate GType
 * for application custom widget classes.
 */
public class Registry : ObjectG
{
	/** the main Gtk struct */
	protected AtkRegistry* atkRegistry;

	/** Get the main Gtk struct */
	public AtkRegistry* getRegistryStruct(bool transferOwnership = false)
	{
		if (transferOwnership)
			ownedRef = false;
		return atkRegistry;
	}

	/** the main Gtk struct as a void* */
	protected override void* getStruct()
	{
		return cast(void*)atkRegistry;
	}

	protected override void setStruct(GObject* obj)
	{
		atkRegistry = cast(AtkRegistry*)obj;
		super.setStruct(obj);
	}

	/**
	 * Sets our main struct and passes it to the parent class.
	 */
	public this (AtkRegistry* atkRegistry, bool ownedRef = false)
	{
		this.atkRegistry = atkRegistry;
		super(cast(GObject*)atkRegistry, ownedRef);
	}


	/** */
	public static GType getType()
	{
		return atk_registry_get_type();
	}

	/**
	 * Gets an #AtkObjectFactory appropriate for creating #AtkObjects
	 * appropriate for @type.
	 *
	 * Params:
	 *     type = a #GType with which to look up the associated #AtkObjectFactory
	 *
	 * Returns: an #AtkObjectFactory appropriate for creating
	 *     #AtkObjects appropriate for @type.
	 */
	public ObjectFactory getFactory(GType type)
	{
		auto p = atk_registry_get_factory(atkRegistry, type);

		if(p is null)
		{
			return null;
		}

		return ObjectG.getDObject!(ObjectFactory)(cast(AtkObjectFactory*) p);
	}

	/**
	 * Provides a #GType indicating the #AtkObjectFactory subclass
	 * associated with @type.
	 *
	 * Params:
	 *     type = a #GType with which to look up the associated #AtkObjectFactory
	 *         subclass
	 *
	 * Returns: a #GType associated with type @type
	 */
	public GType getFactoryType(GType type)
	{
		return atk_registry_get_factory_type(atkRegistry, type);
	}

	/**
	 * Associate an #AtkObjectFactory subclass with a #GType. Note:
	 * The associated @factory_type will thereafter be responsible for
	 * the creation of new #AtkObject implementations for instances
	 * appropriate for @type.
	 *
	 * Params:
	 *     type = an #AtkObject type
	 *     factoryType = an #AtkObjectFactory type to associate with @type.  Must
	 *         implement AtkObject appropriate for @type.
	 */
	public void setFactoryType(GType type, GType factoryType)
	{
		atk_registry_set_factory_type(atkRegistry, type, factoryType);
	}

	/**
	 * Gets a default implementation of the #AtkObjectFactory/type
	 * registry.
	 * Note: For most toolkit maintainers, this will be the correct
	 * registry for registering new #AtkObject factories. Following
	 * a call to this function, maintainers may call atk_registry_set_factory_type()
	 * to associate an #AtkObjectFactory subclass with the GType of objects
	 * for whom accessibility information will be provided.
	 *
	 * Returns: a default implementation of the
	 *     #AtkObjectFactory/type registry
	 */
	public static Registry getDefaultRegistry()
	{
		auto p = atk_get_default_registry();

		if(p is null)
		{
			return null;
		}

		return ObjectG.getDObject!(Registry)(cast(AtkRegistry*) p, true);
	}
}