Added lang-specifig configs
This commit is contained in:
parent
e22147ef2e
commit
ea35f16b38
@ -291,16 +291,16 @@
|
||||
</kdevdoctreeview>
|
||||
<kdevfilecreate>
|
||||
<filetypes>
|
||||
<type icon="source" ext="g" create="template" name="GAP source" >
|
||||
<type icon="source" ext="g" name="GAP source" create="template" >
|
||||
<descr>A new empty GAP source file</descr>
|
||||
</type>
|
||||
<type icon="source_cpp" ext="cpp" create="template" name="C++ Source" >
|
||||
<type icon="source_cpp" ext="cpp" name="C++ Source" create="template" >
|
||||
<descr>A new empty C++ file.</descr>
|
||||
</type>
|
||||
<type icon="source_h" ext="h" create="template" name="C/C++ Header" >
|
||||
<type icon="source_h" ext="h" name="C/C++ Header" create="template" >
|
||||
<descr>A new empty header file for C/C++.</descr>
|
||||
</type>
|
||||
<type icon="source_c" ext="c" create="template" name="C Source" >
|
||||
<type icon="source_c" ext="c" name="C Source" create="template" >
|
||||
<descr>A new empty C file.</descr>
|
||||
</type>
|
||||
</filetypes>
|
||||
|
@ -191,7 +191,6 @@
|
||||
<widget class="GtkHBox" id="hbox1">
|
||||
<property name="visible">True</property>
|
||||
<property name="spacing">3</property>
|
||||
<property name="moo_sensitive">usespaces</property>
|
||||
<child>
|
||||
<widget class="GtkLabel" id="label32">
|
||||
<property name="visible">True</property>
|
||||
@ -309,8 +308,8 @@
|
||||
<property name="can_focus">True</property>
|
||||
<property name="adjustment">1.000000 1.000000 100.000000 1.000000 10.000000 10.000000</property>
|
||||
<property name="climb_rate">1</property>
|
||||
<property name="moo_sensitive">auto_save</property>
|
||||
<property name="moo_prefs_key">auto_save_interval</property>
|
||||
<property name="moo_sensitive">auto_save</property>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="expand">False</property>
|
||||
@ -505,8 +504,8 @@
|
||||
<property name="label">Do not split words</property>
|
||||
<property name="use_underline">True</property>
|
||||
<property name="draw_indicator">True</property>
|
||||
<property name="moo_sensitive">enable_wrapping</property>
|
||||
<property name="moo_prefs_key">wrapping_dont_split_words</property>
|
||||
<property name="moo_sensitive">enable_wrapping</property>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="expand">False</property>
|
||||
@ -742,18 +741,28 @@
|
||||
<property name="n_rows">2</property>
|
||||
<property name="n_columns">2</property>
|
||||
<child>
|
||||
<widget class="GtkComboBox" id="color_scheme_combo">
|
||||
<widget class="GtkLabel" id="label99">
|
||||
<property name="visible">True</property>
|
||||
<property name="items" translatable="yes">KDE
|
||||
gvim
|
||||
</property>
|
||||
<property name="label">Font:</property>
|
||||
<property name="moo_sensitive">!use_default_font</property>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="x_options"></property>
|
||||
<property name="y_options"></property>
|
||||
</packing>
|
||||
</child>
|
||||
<child>
|
||||
<widget class="GtkFontButton" id="fontbutton">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="use_font">True</property>
|
||||
<property name="use_size">True</property>
|
||||
<property name="moo_prefs_key">font</property>
|
||||
<property name="moo_sensitive">!use_default_font</property>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="left_attach">1</property>
|
||||
<property name="right_attach">2</property>
|
||||
<property name="top_attach">1</property>
|
||||
<property name="bottom_attach">2</property>
|
||||
<property name="x_options">GTK_FILL</property>
|
||||
<property name="y_options"></property>
|
||||
</packing>
|
||||
</child>
|
||||
@ -771,28 +780,18 @@ gvim
|
||||
</packing>
|
||||
</child>
|
||||
<child>
|
||||
<widget class="GtkFontButton" id="fontbutton">
|
||||
<widget class="GtkComboBox" id="color_scheme_combo">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="use_font">True</property>
|
||||
<property name="use_size">True</property>
|
||||
<property name="moo_sensitive">!use_default_font</property>
|
||||
<property name="moo_prefs_key">font</property>
|
||||
<property name="items" translatable="yes">KDE
|
||||
gvim
|
||||
</property>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="left_attach">1</property>
|
||||
<property name="right_attach">2</property>
|
||||
<property name="y_options"></property>
|
||||
</packing>
|
||||
</child>
|
||||
<child>
|
||||
<widget class="GtkLabel" id="label99">
|
||||
<property name="visible">True</property>
|
||||
<property name="label">Font:</property>
|
||||
<property name="moo_sensitive">!use_default_font</property>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="x_options"></property>
|
||||
<property name="top_attach">1</property>
|
||||
<property name="bottom_attach">2</property>
|
||||
<property name="x_options">GTK_FILL</property>
|
||||
<property name="y_options"></property>
|
||||
</packing>
|
||||
</child>
|
||||
|
@ -71,6 +71,7 @@ struct _MooEditPrivate {
|
||||
MooEditor *editor;
|
||||
|
||||
gulong modified_changed_handler_id;
|
||||
guint apply_config_idle;
|
||||
|
||||
/***********************************************************************/
|
||||
/* Document
|
||||
|
@ -300,6 +300,9 @@ moo_edit_finalize (GObject *object)
|
||||
edit);
|
||||
g_object_unref (edit->config);
|
||||
|
||||
if (edit->priv->apply_config_idle)
|
||||
g_source_remove (edit->priv->apply_config_idle);
|
||||
|
||||
edit->priv->focus_in_handler_id = 0;
|
||||
if (edit->priv->file_monitor_id)
|
||||
_moo_edit_stop_file_watch (edit);
|
||||
@ -639,15 +642,6 @@ moo_edit_get_editor (MooEdit *doc)
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
moo_edit_set_lang (MooEdit *edit,
|
||||
MooLang *lang)
|
||||
{
|
||||
g_return_if_fail (MOO_IS_EDIT (edit));
|
||||
moo_text_view_set_lang (MOO_TEXT_VIEW (edit), lang);
|
||||
}
|
||||
|
||||
|
||||
typedef void (*SetVarFunc) (MooEdit *edit,
|
||||
char *name,
|
||||
char *val);
|
||||
@ -878,18 +872,66 @@ config_changed (MooEdit *edit,
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
moo_edit_set_lang (MooEdit *edit,
|
||||
MooLang *lang)
|
||||
{
|
||||
MooLang *old_lang;
|
||||
MooEditConfig *config;
|
||||
|
||||
old_lang = moo_text_view_get_lang (MOO_TEXT_VIEW (edit));
|
||||
|
||||
if (old_lang == lang)
|
||||
return;
|
||||
|
||||
_moo_edit_freeze_config_notify (edit);
|
||||
|
||||
moo_edit_config_unset_by_source (edit->config, MOO_EDIT_CONFIG_SOURCE_LANG);
|
||||
config = moo_edit_config_get_for_lang (moo_lang_id (lang));
|
||||
moo_edit_config_compose (edit->config, config);
|
||||
|
||||
moo_text_view_set_lang (MOO_TEXT_VIEW (edit), lang);
|
||||
|
||||
_moo_edit_thaw_config_notify (edit);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
moo_edit_apply_config (MooEdit *edit)
|
||||
{
|
||||
const char *lang_id = moo_edit_config_get_string (edit->config, "lang");
|
||||
MooLangMgr *mgr = moo_editor_get_lang_mgr (edit->priv->editor);
|
||||
MooLang *lang = lang_id ? moo_lang_mgr_get_lang (mgr, lang_id) : NULL;
|
||||
moo_edit_set_lang (edit, lang);
|
||||
}
|
||||
|
||||
|
||||
static gboolean
|
||||
do_apply_config (MooEdit *edit)
|
||||
{
|
||||
edit->priv->apply_config_idle = 0;
|
||||
moo_edit_apply_config (edit);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static void
|
||||
moo_edit_queue_apply_config (MooEdit *edit)
|
||||
{
|
||||
if (!edit->priv->apply_config_idle)
|
||||
edit->priv->apply_config_idle =
|
||||
g_idle_add ((GSourceFunc) do_apply_config, edit);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
moo_edit_config_notify (MooEdit *edit,
|
||||
guint var_id,
|
||||
G_GNUC_UNUSED GParamSpec *pspec)
|
||||
{
|
||||
if (var_id == settings[SETTING_LANG])
|
||||
{
|
||||
const char *value = moo_edit_config_get_string (edit->config, "lang");
|
||||
MooLangMgr *mgr = moo_editor_get_lang_mgr (edit->priv->editor);
|
||||
MooLang *lang = value ? moo_lang_mgr_get_lang (mgr, value) : NULL;
|
||||
moo_edit_set_lang (edit, lang);
|
||||
}
|
||||
moo_edit_apply_config (edit);
|
||||
else
|
||||
moo_edit_queue_apply_config (edit);
|
||||
}
|
||||
|
||||
|
||||
|
@ -15,7 +15,10 @@
|
||||
#define MOOEDIT_COMPILATION
|
||||
|
||||
#include "mooedit/mooeditconfig.h"
|
||||
#include "mooedit/moolang.h"
|
||||
#include "mooedit/mooeditprefs.h"
|
||||
#include "mooutils/mooutils-gobject.h"
|
||||
#include "mooutils/mooprefs.h"
|
||||
#include <gobject/gvaluecollector.h>
|
||||
#include <string.h>
|
||||
|
||||
@ -55,6 +58,7 @@ static GSList *instances;
|
||||
static VarArray *vars;
|
||||
static GQuark prop_id_quark;
|
||||
static GHashTable *aliases;
|
||||
static GHashTable *lang_configs;
|
||||
|
||||
|
||||
static void moo_edit_config_finalize (GObject *object);
|
||||
@ -153,6 +157,9 @@ global_init (void)
|
||||
g_signal_connect (global, "notify",
|
||||
G_CALLBACK (global_changed), NULL);
|
||||
/* XXX read preferences here */
|
||||
|
||||
lang_configs = g_hash_table_new_full (g_str_hash, g_str_equal,
|
||||
g_free, g_object_unref);
|
||||
}
|
||||
}
|
||||
|
||||
@ -347,6 +354,7 @@ moo_edit_config_lookup_spec (const char *name,
|
||||
GParamSpec *pspec;
|
||||
GObjectClass *klass;
|
||||
const char *real_name;
|
||||
char *norm_name;
|
||||
|
||||
g_return_val_if_fail (name != NULL, NULL);
|
||||
|
||||
@ -354,12 +362,13 @@ moo_edit_config_lookup_spec (const char *name,
|
||||
|
||||
klass = g_type_class_ref (MOO_TYPE_EDIT_CONFIG);
|
||||
|
||||
real_name = name;
|
||||
norm_name = g_strdelimit (g_strdup (name), "_", '-');
|
||||
real_name = norm_name;
|
||||
|
||||
if (try_alias)
|
||||
real_name = g_hash_table_lookup (aliases, name);
|
||||
real_name = g_hash_table_lookup (aliases, norm_name);
|
||||
if (!real_name)
|
||||
real_name = name;
|
||||
real_name = norm_name;
|
||||
|
||||
pspec = g_object_class_find_property (klass, real_name);
|
||||
|
||||
@ -372,6 +381,7 @@ moo_edit_config_lookup_spec (const char *name,
|
||||
}
|
||||
|
||||
g_type_class_unref (klass);
|
||||
g_free (norm_name);
|
||||
return pspec;
|
||||
}
|
||||
|
||||
@ -620,6 +630,37 @@ moo_edit_config_unset_by_source (MooEditConfig *config,
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
moo_edit_config_compose (MooEditConfig *target,
|
||||
MooEditConfig *src)
|
||||
{
|
||||
guint i;
|
||||
|
||||
g_return_if_fail (MOO_IS_EDIT_CONFIG (target));
|
||||
g_return_if_fail (MOO_IS_EDIT_CONFIG (src));
|
||||
|
||||
g_object_ref (target);
|
||||
g_object_freeze_notify (G_OBJECT (target));
|
||||
|
||||
for (i = 1; i < vars->len; ++i)
|
||||
{
|
||||
Value *old = VALUE (target, i);
|
||||
Value *new = VALUE (src, i);
|
||||
|
||||
if (old->source < new->source)
|
||||
continue;
|
||||
|
||||
g_value_copy (&new->gval, &old->gval);
|
||||
old->source = new->source;
|
||||
|
||||
object_notify (target, i);
|
||||
}
|
||||
|
||||
g_object_thaw_notify (G_OBJECT (target));
|
||||
g_object_unref (target);
|
||||
}
|
||||
|
||||
|
||||
guint
|
||||
moo_edit_config_get_setting_id (GParamSpec *pspec)
|
||||
{
|
||||
@ -756,3 +797,154 @@ moo_edit_config_install_alias (const char *name,
|
||||
g_hash_table_insert (aliases, s1, g_strdup (pspec->name));
|
||||
g_hash_table_insert (aliases, s2, g_strdup (pspec->name));
|
||||
}
|
||||
|
||||
|
||||
MooEditConfig *
|
||||
moo_edit_config_get_for_lang (const char *lang)
|
||||
{
|
||||
MooEditConfig *config;
|
||||
|
||||
global_init ();
|
||||
|
||||
if (!lang)
|
||||
lang = MOO_LANG_NONE;
|
||||
|
||||
config = g_hash_table_lookup (lang_configs, lang);
|
||||
|
||||
if (!config)
|
||||
{
|
||||
config = moo_edit_config_new ();
|
||||
g_hash_table_insert (lang_configs, g_strdup (lang), config);
|
||||
}
|
||||
|
||||
return config;
|
||||
}
|
||||
|
||||
|
||||
/***************************************************************************/
|
||||
/* Loading and saving
|
||||
*/
|
||||
|
||||
#define ELEMENT_LANG_CONFIG MOO_EDIT_PREFS_PREFIX "/filetypes"
|
||||
#define ELEMENT_LANG "lang"
|
||||
#define PROP_LANG_ID "id"
|
||||
|
||||
static void
|
||||
load_lang_node (MooMarkupNode *lang_node)
|
||||
{
|
||||
const char *lang_id;
|
||||
MooMarkupNode *node;
|
||||
MooEditConfig *config = NULL;
|
||||
|
||||
lang_id = moo_markup_get_prop (lang_node, PROP_LANG_ID);
|
||||
g_return_if_fail (lang_id != NULL);
|
||||
|
||||
for (node = lang_node->children; node != NULL; node = node->next)
|
||||
{
|
||||
if (!MOO_MARKUP_IS_ELEMENT (node))
|
||||
continue;
|
||||
|
||||
if (!moo_edit_config_lookup_spec (node->name, NULL, TRUE))
|
||||
{
|
||||
g_warning ("%s: no property named '%s'",
|
||||
G_STRLOC, node->name);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!config)
|
||||
config = moo_edit_config_get_for_lang (lang_id);
|
||||
|
||||
moo_edit_config_parse (config, node->name,
|
||||
moo_markup_get_content (node),
|
||||
MOO_EDIT_CONFIG_SOURCE_LANG);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
_moo_edit_config_load (void)
|
||||
{
|
||||
MooMarkupDoc *xml;
|
||||
MooMarkupNode *root, *node;
|
||||
|
||||
xml = moo_prefs_get_markup ();
|
||||
g_return_if_fail (xml != NULL);
|
||||
|
||||
root = moo_markup_get_element (MOO_MARKUP_NODE (xml),
|
||||
ELEMENT_LANG_CONFIG);
|
||||
|
||||
if (!root)
|
||||
return;
|
||||
|
||||
for (node = root->children; node != NULL; node = node->next)
|
||||
{
|
||||
if (!MOO_MARKUP_IS_ELEMENT (node))
|
||||
continue;
|
||||
|
||||
if (strcmp (node->name, ELEMENT_LANG))
|
||||
{
|
||||
g_warning ("%s: invalid '%s' element", G_STRLOC, node->name);
|
||||
continue;
|
||||
}
|
||||
|
||||
load_lang_node (node);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
save_config (const char *lang_id,
|
||||
MooEditConfig *config,
|
||||
MooMarkupNode *root)
|
||||
{
|
||||
guint i;
|
||||
MooMarkupNode *lang_node = NULL;
|
||||
|
||||
for (i = 1; i < vars->len; ++i)
|
||||
{
|
||||
Value *val = VALUE (config, i);
|
||||
const char *string;
|
||||
|
||||
if (val->source != MOO_EDIT_CONFIG_SOURCE_LANG)
|
||||
continue;
|
||||
|
||||
string = moo_value_convert_to_string (&val->gval);
|
||||
g_return_if_fail (string != NULL);
|
||||
|
||||
if (!lang_node)
|
||||
{
|
||||
lang_node = moo_markup_create_element (root, ELEMENT_LANG);
|
||||
g_return_if_fail (lang_node != NULL);
|
||||
moo_markup_set_prop (lang_node, PROP_LANG_ID, lang_id);
|
||||
}
|
||||
|
||||
moo_markup_create_text_element (lang_node,
|
||||
vars->data[i].pspec->name,
|
||||
string);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
_moo_edit_config_save (void)
|
||||
{
|
||||
MooMarkupDoc *xml;
|
||||
MooMarkupNode *root;
|
||||
|
||||
xml = moo_prefs_get_markup ();
|
||||
g_return_if_fail (xml != NULL);
|
||||
|
||||
root = moo_markup_get_element (MOO_MARKUP_NODE (xml),
|
||||
ELEMENT_LANG_CONFIG);
|
||||
|
||||
if (root)
|
||||
moo_markup_delete_node (root);
|
||||
|
||||
if (!lang_configs || !g_hash_table_size (lang_configs))
|
||||
return;
|
||||
|
||||
root = moo_markup_create_element (MOO_MARKUP_NODE (xml),
|
||||
ELEMENT_LANG_CONFIG);
|
||||
g_return_if_fail (root != NULL);
|
||||
|
||||
g_hash_table_foreach (lang_configs, (GHFunc) save_config, root);
|
||||
}
|
||||
|
@ -38,8 +38,9 @@ typedef enum {
|
||||
MOO_EDIT_CONFIG_SOURCE_USER = 0,
|
||||
MOO_EDIT_CONFIG_SOURCE_FILE = 10,
|
||||
MOO_EDIT_CONFIG_SOURCE_FILENAME = 20,
|
||||
MOO_EDIT_CONFIG_SOURCE_PREFS = 30,
|
||||
MOO_EDIT_CONFIG_SOURCE_AUTO = 40
|
||||
MOO_EDIT_CONFIG_SOURCE_LANG = 30,
|
||||
MOO_EDIT_CONFIG_SOURCE_PREFS = 40,
|
||||
MOO_EDIT_CONFIG_SOURCE_AUTO = 50
|
||||
} MooEditConfigSource;
|
||||
|
||||
struct _MooEditConfig
|
||||
@ -101,6 +102,13 @@ void moo_edit_config_unset_by_source (MooEditConfig *config,
|
||||
gboolean moo_edit_config_parse_bool (const char *string,
|
||||
gboolean *value);
|
||||
|
||||
void moo_edit_config_compose (MooEditConfig *target,
|
||||
MooEditConfig *src);
|
||||
|
||||
MooEditConfig *moo_edit_config_get_for_lang (const char *lang);
|
||||
void _moo_edit_config_load (void);
|
||||
void _moo_edit_config_save (void);
|
||||
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
|
@ -283,6 +283,7 @@ moo_editor_init (MooEditor *editor)
|
||||
NULL, (GDestroyNotify) moo_edit_saver_unref);
|
||||
|
||||
moo_prefs_new_key_string (moo_edit_setting (MOO_EDIT_PREFS_DEFAULT_LANG), NULL);
|
||||
_moo_edit_config_load ();
|
||||
|
||||
editor->priv->prefs_notify =
|
||||
moo_prefs_notify_connect (MOO_EDIT_PREFS_PREFIX "/[^/]*",
|
||||
|
Loading…
x
Reference in New Issue
Block a user