aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2002-11-02 13:16:24 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2002-11-02 13:16:24 +0800
commit236c15d106b4e740d4e3996e0649334ca8e13876 (patch)
treef98b59632e0bf927288650393e49060950c7ad9e
parent9fd7dd8e0ca925b2aa738b1c495ff3b41f0f2487 (diff)
downloadgsoc2013-evolution-236c15d106b4e740d4e3996e0649334ca8e13876.tar.gz
gsoc2013-evolution-236c15d106b4e740d4e3996e0649334ca8e13876.tar.zst
gsoc2013-evolution-236c15d106b4e740d4e3996e0649334ca8e13876.zip
Ported this too.
2002-11-02 Jeffrey Stedfast <fejj@ximian.com> * filter-context.c: Ported this too. * rule-context.c: Ported to glib2/GObject. svn path=/trunk/; revision=18502
-rw-r--r--filter/ChangeLog2
-rw-r--r--filter/filter-context.c224
-rw-r--r--filter/filter-context.h35
-rw-r--r--filter/rule-context.c10
-rw-r--r--filter/rule-context.h71
5 files changed, 171 insertions, 171 deletions
diff --git a/filter/ChangeLog b/filter/ChangeLog
index c9d33d7c10..7b81ec9b20 100644
--- a/filter/ChangeLog
+++ b/filter/ChangeLog
@@ -1,5 +1,7 @@
2002-11-02 Jeffrey Stedfast <fejj@ximian.com>
+ * filter-context.c: Ported this too.
+
* rule-context.c: Ported to glib2/GObject.
2002-11-01 Jeffrey Stedfast <fejj@ximian.com>
diff --git a/filter/filter-context.c b/filter/filter-context.c
index 6740af5b9e..c1dc6d8545 100644
--- a/filter/filter-context.c
+++ b/filter/filter-context.c
@@ -1,7 +1,9 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
- * Copyright (C) 2000 Ximian Inc.
+ * Copyright (C) 2000-2002 Ximian Inc.
*
* Authors: Not Zed <notzed@lostzed.mmc.com.au>
+ * Jeffrey Stedfast <fejj@ximian.com>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of version 2 of the GNU General Public
@@ -18,15 +20,13 @@
* Boston, MA 02111-1307, USA.
*/
+
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <string.h>
-#include <gtk/gtktypeutils.h>
-#include <gtk/gtkobject.h>
-
#include "filter-context.h"
#include "filter-filter.h"
@@ -35,92 +35,80 @@
#define d(x)
-static void filter_context_class_init (FilterContextClass *class);
-static void filter_context_init (FilterContext *gspaper);
-static void filter_context_finalise (GtkObject *obj);
-
-static GList *filter_rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp);
-static GList *filter_delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp);
-
-#define _PRIVATE(x) (((FilterContext *)(x))->priv)
+static void filter_context_class_init (FilterContextClass *klass);
+static void filter_context_init (FilterContext *fc);
+static void filter_context_finalise (GObject *obj);
-struct _FilterContextPrivate {
-};
+static GList *filter_rename_uri (RuleContext *rc, const char *olduri, const char *newuri, GCompareFunc cmp);
+static GList *filter_delete_uri (RuleContext *rc, const char *uri, GCompareFunc cmp);
-static RuleContextClass *parent_class;
-enum {
- LAST_SIGNAL
-};
+static RuleContextClass *parent_class = NULL;
-static guint signals[LAST_SIGNAL] = { 0 };
-guint
+GType
filter_context_get_type (void)
{
- static guint type = 0;
+ static GType type = 0;
if (!type) {
- GtkTypeInfo type_info = {
- "FilterContext",
- sizeof(FilterContext),
- sizeof(FilterContextClass),
- (GtkClassInitFunc)filter_context_class_init,
- (GtkObjectInitFunc)filter_context_init,
- (GtkArgSetFunc)NULL,
- (GtkArgGetFunc)NULL
+ static const GTypeInfo info = {
+ sizeof (FilterContextClass),
+ NULL, /* base_class_init */
+ NULL, /* base_class_finalize */
+ (GClassInitFunc) filter_context_class_init,
+ NULL, /* class_finalize */
+ NULL, /* class_data */
+ sizeof (FilterContext),
+ 0, /* n_preallocs */
+ (GInstanceInitFunc) filter_context_init,
};
- type = gtk_type_unique(rule_context_get_type (), &type_info);
+ type = g_type_register_static (RULE_TYPE_CONTEXT, "FilterContext", &info, 0);
}
return type;
}
static void
-filter_context_class_init (FilterContextClass *class)
+filter_context_class_init (FilterContextClass *klass)
{
- GtkObjectClass *object_class;
- RuleContextClass *rule_class = (RuleContextClass *)class;
-
- object_class = (GtkObjectClass *)class;
- parent_class = gtk_type_class(rule_context_get_type ());
-
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+ RuleContextClass *rc_class = RULE_CONTEXT_CLASS (klass);
+
+ parent_class = g_type_class_ref (RULE_TYPE_CONTEXT);
+
object_class->finalize = filter_context_finalise;
-
+
/* override methods */
- rule_class->rename_uri = filter_rename_uri;
- rule_class->delete_uri = filter_delete_uri;
-
- /* signals */
-
- gtk_object_class_add_signals(object_class, signals, LAST_SIGNAL);
+ rc_class->rename_uri = filter_rename_uri;
+ rc_class->delete_uri = filter_delete_uri;
}
static void
-filter_context_init (FilterContext *o)
+filter_context_init (FilterContext *fc)
{
- o->priv = g_malloc0(sizeof(*o->priv));
-
- rule_context_add_part_set((RuleContext *)o, "partset", filter_part_get_type(),
- rule_context_add_part, rule_context_next_part);
- rule_context_add_part_set((RuleContext *)o, "actionset", filter_part_get_type(),
- (RCPartFunc)filter_context_add_action,
- (RCNextPartFunc)filter_context_next_action);
-
- rule_context_add_rule_set((RuleContext *)o, "ruleset", filter_filter_get_type(),
- (RCRuleFunc)rule_context_add_rule, rule_context_next_rule);
+ fc->priv = g_malloc0 (sizeof (*rc->priv));
+
+ rule_context_add_part_set ((RuleContext *) fc, "partset", filter_part_get_type (),
+ rule_context_add_part, rule_context_next_part);
+ rule_context_add_part_set ((RuleContext *) fc, "actionset", filter_part_get_type (),
+ (RCPartFunc) filter_context_add_action,
+ (RCNextPartFunc) filter_context_next_action);
+
+ rule_context_add_rule_set ((RuleContext *) fc, "ruleset", filter_filter_get_type (),
+ (RCRuleFunc) rule_context_add_rule, rule_context_next_rule);
}
static void
-filter_context_finalise(GtkObject *obj)
+filter_context_finalise (GObject *obj)
{
- FilterContext *o = (FilterContext *)obj;
-
- g_list_foreach(o->actions, (GFunc)gtk_object_unref, NULL);
- g_list_free(o->actions);
-
- ((GtkObjectClass *)(parent_class))->finalize(obj);
+ FilterContext *fc = (FilterContext *)obj;
+
+ g_list_foreach (fc->actions, (GFunc)g_object_unref, NULL);
+ g_list_free (fc->actions);
+
+ G_OBJECT_CLASS (parent_class)->finalize (obj);
}
/**
@@ -131,41 +119,45 @@ filter_context_finalise(GtkObject *obj)
* Return value: A new #FilterContext object.
**/
FilterContext *
-filter_context_new(void)
+filter_context_new (void)
{
- FilterContext *o = (FilterContext *)gtk_type_new(filter_context_get_type ());
- return o;
+ return (FilterContext *) g_object_new (FILTER_TYPE_CONTEXT, NULL, NULL);
}
-void filter_context_add_action(FilterContext *f, FilterPart *action)
+void
+filter_context_add_action (FilterContext *fc, FilterPart *action)
{
d(printf("find action : "));
- f->actions = g_list_append(f->actions, action);
+ fc->actions = g_list_append (fc->actions, action);
}
-FilterPart *filter_context_find_action(FilterContext *f, const char *name)
+FilterPart *
+filter_context_find_action (FilterContext *fc, const char *name)
{
d(printf("find action : "));
- return filter_part_find_list(f->actions, name);
+ return filter_part_find_list (fc->actions, name);
}
-FilterPart *filter_context_create_action(FilterContext *f, const char *name)
+FilterPart *
+filter_context_create_action (FilterContext *fc, const char *name)
{
FilterPart *part;
-
- part = filter_context_find_action(f, name);
- if (part)
- part = filter_part_clone(part);
- return part;
+
+ if ((part = filter_context_find_action (fc, name)))
+ return filter_part_clone (part);
+
+ return NULL;
}
-FilterPart *filter_context_next_action(FilterContext *f, FilterPart *last)
+FilterPart *
+filter_context_next_action (FilterContext *fc, FilterPart *last)
{
- return filter_part_next_list(f->actions, last);
+ return filter_part_next_list (fc->actions, last);
}
/* We search for any folders in our actions list that need updating, update them */
-static GList *filter_rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp)
+static GList *
+filter_rename_uri (RuleContext *rc, const char *olduri, const char *newuri, GCompareFunc cmp)
{
FilterRule *rule;
GList *l, *el;
@@ -173,32 +165,34 @@ static GList *filter_rename_uri(RuleContext *f, const char *olduri, const char *
FilterElement *element;
int count = 0;
GList *changed = NULL;
-
+
d(printf("uri '%s' renamed to '%s'\n", olduri, newuri));
-
+
/* For all rules, for all actions, for all elements, rename any folder elements */
/* Yes we could do this inside each part itself, but not today */
rule = NULL;
- while ( (rule = rule_context_next_rule(f, rule, NULL)) ) {
+ while ((rule = rule_context_next_rule (rc, rule, NULL))) {
int rulecount = 0;
-
+
d(printf("checking rule '%s'\n", rule->name));
- l = FILTER_FILTER(rule)->actions;
+ l = FILTER_FILTER (rule)->actions;
while (l) {
action = l->data;
-
+
d(printf("checking action '%s'\n", action->name));
el = action->elements;
while (el) {
element = el->data;
-
+
d(printf("checking element '%s'\n", element->name));
- if (IS_FILTER_FOLDER(element))
- d(printf(" is folder, existing uri = '%s'\n", FILTER_FOLDER(element)->uri));
-
- if (IS_FILTER_FOLDER(element)
+ if (IS_FILTER_FOLDER (element)) {
+ d(printf(" is folder, existing uri = '%s'\n",
+ FILTER_FOLDER (element)->uri));
+ }
+
+ if (IS_FILTER_FOLDER (element)
&& cmp(((FilterFolder *)element)->uri, olduri)) {
d(printf(" Changed!\n"));
filter_folder_set_value((FilterFolder *)element, newuri);
@@ -208,66 +202,69 @@ static GList *filter_rename_uri(RuleContext *f, const char *olduri, const char *
}
l = l->next;
}
-
+
if (rulecount) {
- changed = g_list_append(changed, g_strdup(rule->name));
- filter_rule_emit_changed(rule);
+ changed = g_list_append (changed, g_strdup (rule->name));
+ filter_rule_emit_changed (rule);
}
-
+
count += rulecount;
}
-
+
/* might need to call parent class, if it did anything ... parent_class->rename_uri(f, olduri, newuri, cmp); */
-
+
return changed;
}
-static GList *filter_delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp)
+static GList *
+filter_delete_uri (RuleContext *rc, const char *uri, GCompareFunc cmp)
{
/* We basically do similar to above, but when we find it,
Remove the action, and if thats the last action, this might create an empty rule? remove the rule? */
-
+
FilterRule *rule;
GList *l, *el;
FilterPart *action;
FilterElement *element;
int count = 0;
GList *deleted = NULL;
-
+
d(printf("uri '%s' deleted\n", uri));
-
+
/* For all rules, for all actions, for all elements, check deleted folder elements */
/* Yes we could do this inside each part itself, but not today */
rule = NULL;
- while ( (rule = rule_context_next_rule(f, rule, NULL)) ) {
+ while ((rule = rule_context_next_rule (rc, rule, NULL))) {
int recorded = 0;
-
+
d(printf("checking rule '%s'\n", rule->name));
- l = FILTER_FILTER(rule)->actions;
+ l = FILTER_FILTER (rule)->actions;
while (l) {
action = l->data;
-
+
d(printf("checking action '%s'\n", action->name));
el = action->elements;
while (el) {
element = el->data;
-
+
d(printf("checking element '%s'\n", element->name));
- if (IS_FILTER_FOLDER(element))
- d(printf(" is folder, existing uri = '%s'\n", FILTER_FOLDER(element)->uri));
-
- if (IS_FILTER_FOLDER(element)
+ if (IS_FILTER_FOLDER (element)) {
+ d(printf(" is folder, existing uri = '%s'\n",
+ FILTER_FOLDER (element)->uri));
+ }
+
+ if (IS_FILTER_FOLDER (element)
&& cmp(((FilterFolder *)element)->uri, uri)) {
d(printf(" Deleted!\n"));
/* check if last action, if so, remove rule instead? */
l = l->next;
- filter_filter_remove_action((FilterFilter *)rule, action);
- gtk_object_unref((GtkObject *)action);
+ filter_filter_remove_action ((FilterFilter *)rule, action);
+ g_object_unref (action);
count++;
if (!recorded)
- deleted = g_list_append(deleted, g_strdup(rule->name));
+ deleted = g_list_append (deleted, g_strdup (rule->name));
goto next_action;
}
el = el->next;
@@ -277,9 +274,8 @@ static GList *filter_delete_uri(RuleContext *f, const char *uri, GCompareFunc cm
;
}
}
-
+
/* TODO: could call parent and merge lists */
-
+
return deleted;
}
-
diff --git a/filter/filter-context.h b/filter/filter-context.h
index 93feb3b8b2..157ee6f1de 100644
--- a/filter/filter-context.h
+++ b/filter/filter-context.h
@@ -26,36 +26,37 @@
#include "rule-context.h"
-#define FILTER_CONTEXT(obj) GTK_CHECK_CAST (obj, filter_context_get_type (), FilterContext)
-#define FILTER_CONTEXT_CLASS(klass) GTK_CHECK_CLASS_CAST (klass, filter_context_get_type (), FilterContextClass)
-#define IS_FILTER_CONTEXT(obj) GTK_CHECK_TYPE (obj, filter_context_get_type ())
+#define FILTER_TYPE_CONTEXT (filter_context_get_type ())
+#define FILTER_CONTEXT(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), FILTER_TYPE_CONTEXT, FilterContext))
+#define FILTER_CONTEXT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), FILTER_TYPE_CONTEXT, FilterContextClass))
+#define IS_FILTER_CONTEXT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), FILTER_TYPE_CONTEXT))
+#define IS_FILTER_CONTEXT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), FILTER_TYPE_CONTEXT))
+#define FILTER_CONTEXT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), FILTER_TYPE_CONTEXT, FilterContextClass))
-typedef struct _FilterContext FilterContext;
-typedef struct _FilterContextClass FilterContextClass;
+typedef struct _FilterContext FilterContext;
+typedef struct _FilterContextClass FilterContextClass;
struct _FilterContext {
- RuleContext parent;
- struct _FilterContextPrivate *priv;
-
+ RuleContext parent_object;
+
GList *actions;
};
struct _FilterContextClass {
RuleContextClass parent_class;
-
+
/* virtual methods */
-
+
/* signals */
};
-guint filter_context_get_type (void);
-FilterContext *filter_context_new (void);
+GType filter_context_get_type (void);
+FilterContext *filter_context_new (void);
/* methods */
-void filter_context_add_action(FilterContext *f, FilterPart *action);
-FilterPart *filter_context_find_action(FilterContext *f, const char *name);
-FilterPart *filter_context_create_action(FilterContext *f, const char *name);
-FilterPart *filter_context_next_action(FilterContext *f, FilterPart *last);
+void filter_context_add_action (FilterContext *fc, FilterPart *action);
+FilterPart *filter_context_find_action (FilterContext *fc, const char *name);
+FilterPart *filter_context_create_action (FilterContext *fc, const char *name);
+FilterPart *filter_context_next_action (FilterContext *fc, FilterPart *last);
#endif /* ! _FILTER_CONTEXT_H */
-
diff --git a/filter/rule-context.c b/filter/rule-context.c
index 69de387100..4d0566943c 100644
--- a/filter/rule-context.c
+++ b/filter/rule-context.c
@@ -41,11 +41,11 @@
#define d(x)
-static int load(RuleContext * f, const char *system, const char *user);
-static int save(RuleContext * f, const char *user);
-static int revert(RuleContext *f, const char *user);
-static GList *rename_uri(RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp);
-static GList *delete_uri(RuleContext *f, const char *uri, GCompareFunc cmp);
+static int load (RuleContext *rc, const char *system, const char *user);
+static int save (RuleContext *rc, const char *user);
+static int revert (RuleContext *rc, const char *user);
+static GList *rename_uri (RuleContext *rc, const char *olduri, const char *newuri, GCompareFunc cmp);
+static GList *delete_uri (RuleContext *rc, const char *uri, GCompareFunc cmp);
static void rule_context_class_init (RuleContextClass *klass);
static void rule_context_init (RuleContext *rc);
diff --git a/filter/rule-context.h b/filter/rule-context.h
index 62e6f4ac19..96bc06b00d 100644
--- a/filter/rule-context.h
+++ b/filter/rule-context.h
@@ -20,6 +20,7 @@
* Boston, MA 02111-1307, USA.
*/
+
#ifndef _RULE_CONTEXT_H
#define _RULE_CONTEXT_H
@@ -58,29 +59,29 @@ struct _RuleContext {
GList *rule_set_list;
};
-typedef void (*RCRegisterFunc) (RuleContext *f, FilterRule *rule, gpointer user_data);
+typedef void (*RCRegisterFunc) (RuleContext *rc, FilterRule *rule, gpointer user_data);
struct _RuleContextClass {
GObjectClass parent_class;
/* virtual methods */
- int (*load) (RuleContext *f, const char *system, const char *user);
- int (*save) (RuleContext *f, const char *user);
- int (*revert) (RuleContext *f, const char *user);
+ int (*load) (RuleContext *rc, const char *system, const char *user);
+ int (*save) (RuleContext *rc, const char *user);
+ int (*revert) (RuleContext *rc, const char *user);
- GList *(*delete_uri) (RuleContext *f, const char *uri, GCompareFunc cmp);
- GList *(*rename_uri) (RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp);
+ GList *(*delete_uri) (RuleContext *rc, const char *uri, GCompareFunc cmp);
+ GList *(*rename_uri) (RuleContext *rc, const char *olduri, const char *newuri, GCompareFunc cmp);
/* signals */
- void (*rule_added) (RuleContext *f, FilterRule *rule);
- void (*rule_removed) (RuleContext *f, FilterRule *rule);
- void (*changed) (RuleContext *f);
+ void (*rule_added) (RuleContext *rc, FilterRule *rule);
+ void (*rule_removed) (RuleContext *rc, FilterRule *rule);
+ void (*changed) (RuleContext *rc);
};
-typedef void (*RCPartFunc) (RuleContext *f, FilterPart *part);
-typedef void (*RCRuleFunc) (RuleContext *f, FilterRule *part);
-typedef FilterPart * (*RCNextPartFunc) (RuleContext *f, FilterPart *part);
-typedef FilterRule * (*RCNextRuleFunc) (RuleContext *f, FilterRule *rule, const char *source);
+typedef void (*RCPartFunc) (RuleContext *rc, FilterPart *part);
+typedef void (*RCRuleFunc) (RuleContext *rc, FilterRule *part);
+typedef FilterPart * (*RCNextPartFunc) (RuleContext *rc, FilterPart *part);
+typedef FilterRule * (*RCNextRuleFunc) (RuleContext *rc, FilterRule *rule, const char *source);
struct _part_set_map {
char *name;
@@ -100,36 +101,36 @@ GType rule_context_get_type (void);
RuleContext *rule_context_new (void);
/* methods */
-int rule_context_load (RuleContext *f, const char *system, const char *user);
-int rule_context_save (RuleContext *f, const char *user);
-int rule_context_revert (RuleContext *f, const char *user);
-
-void rule_context_add_part (RuleContext *f, FilterPart *new);
-FilterPart *rule_context_find_part (RuleContext *f, const char *name);
-FilterPart *rule_context_create_part (RuleContext *f, const char *name);
-FilterPart *rule_context_next_part (RuleContext *f, FilterPart *last);
-
-FilterRule *rule_context_next_rule (RuleContext *f, FilterRule *last, const char *source);
-FilterRule *rule_context_find_rule (RuleContext *f, const char *name, const char *source);
-FilterRule *rule_context_find_rank_rule (RuleContext *f, int rank, const char *source);
-void rule_context_add_rule (RuleContext *f, FilterRule *new);
-void rule_context_add_rule_gui (RuleContext *f, FilterRule *rule, const char *title, const char *path);
-void rule_context_remove_rule (RuleContext *f, FilterRule *rule);
+int rule_context_load (RuleContext *rc, const char *system, const char *user);
+int rule_context_save (RuleContext *rc, const char *user);
+int rule_context_revert (RuleContext *rc, const char *user);
+
+void rule_context_add_part (RuleContext *rc, FilterPart *new);
+FilterPart *rule_context_find_part (RuleContext *rc, const char *name);
+FilterPart *rule_context_create_part (RuleContext *rc, const char *name);
+FilterPart *rule_context_next_part (RuleContext *rc, FilterPart *last);
+
+FilterRule *rule_context_next_rule (RuleContext *rc, FilterRule *last, const char *source);
+FilterRule *rule_context_find_rule (RuleContext *rc, const char *name, const char *source);
+FilterRule *rule_context_find_rank_rule (RuleContext *rc, int rank, const char *source);
+void rule_context_add_rule (RuleContext *rc, FilterRule *new);
+void rule_context_add_rule_gui (RuleContext *rc, FilterRule *rule, const char *title, const char *path);
+void rule_context_remove_rule (RuleContext *rc, FilterRule *rule);
/* get/set the rank (position) of a rule */
-void rule_context_rank_rule (RuleContext *f, FilterRule *rule, int rank);
-int rule_context_get_rank_rule (RuleContext *f, FilterRule *rule, const char *source);
+void rule_context_rank_rule (RuleContext *rc, FilterRule *rule, int rank);
+int rule_context_get_rank_rule (RuleContext *rc, FilterRule *rule, const char *source);
/* setup type for set parts */
-void rule_context_add_part_set (RuleContext *f, const char *setname, int part_type,
+void rule_context_add_part_set (RuleContext *rc, const char *setname, int part_type,
RCPartFunc append, RCNextPartFunc next);
-void rule_context_add_rule_set (RuleContext *f, const char *setname, int rule_type,
+void rule_context_add_rule_set (RuleContext *rc, const char *setname, int rule_type,
RCRuleFunc append, RCNextRuleFunc next);
/* uri's disappear/renamed externally */
-GList *rule_context_delete_uri (RuleContext *f, const char *uri, GCompareFunc cmp);
-GList *rule_context_rename_uri (RuleContext *f, const char *olduri, const char *newuri, GCompareFunc cmp);
+GList *rule_context_delete_uri (RuleContext *rc, const char *uri, GCompareFunc cmp);
+GList *rule_context_rename_uri (RuleContext *rc, const char *olduri, const char *newuri, GCompareFunc cmp);
-void rule_context_free_uri_list (RuleContext *f, GList *uris);
+void rule_context_free_uri_list (RuleContext *rc, GList *uris);
#endif /* ! _RULE_CONTEXT_H */