Tue, 06 Jan 2015 21:39:09 +0100
Conditionally force memory storage according to privacy.thirdparty.isolate;
This solves Tor bug #9701, complying with disk avoidance documented in
https://www.torproject.org/projects/torbrowser/design/#disk-avoidance.
michael@0 | 1 | /* ATK - Accessibility Toolkit |
michael@0 | 2 | * Copyright 2001 Sun Microsystems Inc. |
michael@0 | 3 | * |
michael@0 | 4 | * This library is free software; you can redistribute it and/or |
michael@0 | 5 | * modify it under the terms of the GNU Library General Public |
michael@0 | 6 | * License as published by the Free Software Foundation; either |
michael@0 | 7 | * version 2 of the License, or (at your option) any later version. |
michael@0 | 8 | * |
michael@0 | 9 | * This library is distributed in the hope that it will be useful, |
michael@0 | 10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
michael@0 | 11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
michael@0 | 12 | * Library General Public License for more details. |
michael@0 | 13 | * |
michael@0 | 14 | * You should have received a copy of the GNU Library General Public |
michael@0 | 15 | * License along with this library; if not, write to the |
michael@0 | 16 | * Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
michael@0 | 17 | * Boston, MA 02111-1307, USA. |
michael@0 | 18 | */ |
michael@0 | 19 | |
michael@0 | 20 | #ifndef __ATK_RELATION_H__ |
michael@0 | 21 | #define __ATK_RELATION_H__ |
michael@0 | 22 | |
michael@0 | 23 | #ifdef __cplusplus |
michael@0 | 24 | extern "C" { |
michael@0 | 25 | #endif /* __cplusplus */ |
michael@0 | 26 | |
michael@0 | 27 | #include <glib-object.h> |
michael@0 | 28 | #include <atk/atkrelationtype.h> |
michael@0 | 29 | |
michael@0 | 30 | /* |
michael@0 | 31 | * An AtkRelation describes a relation between the object and one or more |
michael@0 | 32 | * other objects. The actual relations that an object has with other objects |
michael@0 | 33 | * are defined as an AtkRelationSet, which is a set of AtkRelations. |
michael@0 | 34 | */ |
michael@0 | 35 | |
michael@0 | 36 | #define ATK_TYPE_RELATION (atk_relation_get_type ()) |
michael@0 | 37 | #define ATK_RELATION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), ATK_TYPE_RELATION, AtkRelation)) |
michael@0 | 38 | #define ATK_RELATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), ATK_TYPE_RELATION, AtkRelationClass)) |
michael@0 | 39 | #define ATK_IS_RELATION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), ATK_TYPE_RELATION)) |
michael@0 | 40 | #define ATK_IS_RELATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), ATK_TYPE_RELATION)) |
michael@0 | 41 | #define ATK_RELATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), ATK_TYPE_RELATION, AtkRelationClass)) |
michael@0 | 42 | |
michael@0 | 43 | typedef struct _AtkRelation AtkRelation; |
michael@0 | 44 | typedef struct _AtkRelationClass AtkRelationClass; |
michael@0 | 45 | |
michael@0 | 46 | struct _AtkRelation |
michael@0 | 47 | { |
michael@0 | 48 | GObject parent; |
michael@0 | 49 | |
michael@0 | 50 | GPtrArray *target; |
michael@0 | 51 | AtkRelationType relationship; |
michael@0 | 52 | }; |
michael@0 | 53 | |
michael@0 | 54 | struct _AtkRelationClass |
michael@0 | 55 | { |
michael@0 | 56 | GObjectClass parent; |
michael@0 | 57 | }; |
michael@0 | 58 | |
michael@0 | 59 | GType atk_relation_get_type (void); |
michael@0 | 60 | |
michael@0 | 61 | AtkRelationType atk_relation_type_register (const gchar *name); |
michael@0 | 62 | G_CONST_RETURN gchar* atk_relation_type_get_name (AtkRelationType type); |
michael@0 | 63 | AtkRelationType atk_relation_type_for_name (const gchar *name); |
michael@0 | 64 | |
michael@0 | 65 | /* |
michael@0 | 66 | * Create a new relation for the specified key and the specified list |
michael@0 | 67 | * of targets. |
michael@0 | 68 | */ |
michael@0 | 69 | AtkRelation* atk_relation_new (AtkObject **targets, |
michael@0 | 70 | gint n_targets, |
michael@0 | 71 | AtkRelationType relationship); |
michael@0 | 72 | /* |
michael@0 | 73 | * Returns the type of a relation. |
michael@0 | 74 | */ |
michael@0 | 75 | AtkRelationType atk_relation_get_relation_type (AtkRelation *relation); |
michael@0 | 76 | /* |
michael@0 | 77 | * Returns the target list of a relation. |
michael@0 | 78 | */ |
michael@0 | 79 | GPtrArray* atk_relation_get_target (AtkRelation *relation); |
michael@0 | 80 | void atk_relation_add_target (AtkRelation *relation, |
michael@0 | 81 | AtkObject *target); |
michael@0 | 82 | |
michael@0 | 83 | |
michael@0 | 84 | #ifdef __cplusplus |
michael@0 | 85 | } |
michael@0 | 86 | #endif /* __cplusplus */ |
michael@0 | 87 | |
michael@0 | 88 | #endif /* __ATK_RELATION_H__ */ |