var Xex = {
LogNode: null,
- LogSuspended: '',
- Log: function (arg, indent, suspend)
+ Log: function (arg, indent)
{
if (! Xex.LogNode)
return;
if (! arg)
Xex.LogNode.value = '';
- else if (suspend)
- Xex.LogSuspended += arg;
else
{
- var str = Xex.LogSuspended;
- Xex.LogSuspended = '';
+ var str = '';
if (indent != undefined)
for (var i = 0; i <= indent; i++)
str += ' ';
- Xex.LogNode.value = str + arg + "\n" + Xex.LogNode.value;
+ Xex.LogNode.value += "\n" + str + arg;
+ Xex.LogNode.scrollTop = Xex.LogNode.scrollHeight;
}
}
};
MIM.Key = function (val)
{
this.key;
- this.has_modifier = false;
if (val instanceof Xex.Term)
this.key = val.val;
else if (typeof val == 'string' || val instanceof String)
MIM.KeySeq = function (seq)
{
this.val = new Array ();
- this.has_modifier = false;
if (seq)
{
selectors["@>"] = selectors["@last"] = new MIM.Selector ('@>');
selectors["@-"] = selectors["@previous"] = new MIM.Selector ('@-');
selectors["@+"] = selectors["@next"] = new MIM.Selector ('@+');
- selectors["@["] = selectors["@previous-candidate-change"]
- = new MIM.Selector ('@[');
- selectors["@]"] = selectors["@next-candidate-change"]
- = new MIM.Selector ('@]');
+ selectors["@["] = selectors["@previous-group"] = new MIM.Selector ('@[');
+ selectors["@]"] = selectors["@next-group"] = new MIM.Selector ('@]');
MIM.Selector.prototype.Parser = function (domain, node)
{
var sub;
if (index < keys.val.length && this.submaps
+ && ! keys.val[index])
+ {
+ Xex.Log ('invalid key at ' + index);
+ throw 'invalid key';
+ }
+
+ if (index < keys.val.length && this.submaps
&& (sub = this.submaps[keys.val[index].key]))
{
index++;
function handle_key ()
{
- var out = this.keymap.Lookup (this.keys, this.key_head);
+ Xex.Log ('Key(' + this.key_head + ') "' + this.keys.val[this.key_head]
+ + '" in ' + this.state.name + ':' + this.keymap.name
+ + " key/state/commit-head/len:"
+ + this.key_head + '/' + this.state_key_head + '/' + this.commit_key_head + '/' + this.keys.val.length);
+ var out = this.state.keymap.Lookup (this.keys, this.state_key_head);
var sub = out.map;
- Xex.Log ('handling ' + this.keys.val[this.key_head]
- + ' in ' + this.state.name + ':' + this.keymap.name, 0, true);
- this.key_head = out.index;
- if (sub != this.keymap)
+ if (out.index > this.key_head)
{
- Xex.Log (' with submap');
+ this.key_head = out.index;
+ Xex.Log (' with submap for ' + this.key_head + 'keys');
restore_state.call (this);
this.keymap = sub;
- if (this.keymap.map_actions)
+ if (sub.map_actions)
{
Xex.Log ('taking map actions:');
- if (! this.take_actions (this.keymap.map_actions))
+ if (! this.take_actions (sub.map_actions))
return false;
}
- else if (this.keymap.submaps)
+ else if (sub.submaps)
{
Xex.Log ('no map actions');
for (var i = this.state_key_head; i < this.key_head; i++)
this.ins (this.keys.val[i].key, null);
}
}
- if (! this.keymap.submaps)
+ if (! sub.submaps)
{
Xex.Log ('terminal:');
if (this.keymap.branch_actions != null)
if (! this.take_actions (this.keymap.branch_actions))
return false;
}
- if (this.keymap != this.state.keymap)
+ if (sub != this.state.keymap)
this.shift (this.state);
}
}
else
{
Xex.Log (' without submap');
+ this.keymap = sub;
var current_state = this.state;
var map = this.keymap;
if (this.key_head > this.keys.val.length)
this.key_head = this.keys.val.length;
}
+ Xex.Log ('0: key head = ' + this.key_head);
},
pop: function ()
{
this.commit ();
this.keys.val.splice (0, this.key_head);
- this.key_head = 0;
+ this.key_head = this.state_key_head = this.commit_key_head = 0;
this.prev_state = null;
}
}
this.changed |= MIM.ChangedStatus.StateTitle;
this.state = state;
this.keymap = state.keymap;
- this.state_key_head = this.key_head;
save_state.call (this);
},
{
if (! this.active)
{
+ Xex.Log ("active = false");
this.key_unhandled = true;
this.unhandled_key = key;
return false;
this.key_unhandled = false;
this.keys.val.push (key);
var count = 0;
+ Xex.Log ("keyhead=" + this.key_head + " len="+this.keys.val.length);
while (this.key_head < this.keys.val.length)
{
if (! handle_key.call (this))
if (this.key_unhandled)
{
this.keys.val.length = 0;
+ //this.keys.val.splice (0, this.keys.val.length);
this.key_head = this.state_key_head = this.commit_key_head = 0;
}
return (! this.key_unhandled
{
var target = event.target;
var ic = target.mim_ic;
- if (ic)
- {
- if (target.mim_ignore_focus_in)
- {
- Xex.Log ('ignore focus_in in ' + target.tagName);
- // Ignore this event which is caused by setSelectionRange ().
- target.mim_ignore_focus_in = false;
- event.preventDefault ();
- }
- else
- {
- Xex.Log ('focus_in in ' + target.tagName);
- try {
- ic.Filter (MIM.Key.FocusIn);
- MIM.update (target, ic);
- // Ignore further focus-in caused by setSelectionRange ().
- // target.mim_ignore_focus_in = true;
- }
- catch (e) { Xex.Log ('Error:' + e); throw (e); }
- }
- }
-}
-
-MIM.cancel_ignore_focus = function ()
-{
- if (MIM.focus_ignore_target)
+ if (ic.wait_update == true)
{
- MIM.focus_ignore_target.mim_ignore_focus_in = false;
- MIM.focus_ignore_target.mim_ignore_focus_out = false;
+ Xex.Log ("Focus in " + target.tagName + ' IGNORED');
+ event.preventDefault ();
+ return false;
}
+ Xex.Log ("Focus in " + target.tagName);
+ ic.Filter (MIM.Key.FocusIn);
+ MIM.update (target, ic);
}
MIM.focus_out = function (event)
{
var target = event.target;
var ic = target.mim_ic;
- if (ic)
+ function reset_update () { ic.wait_update = false; };
+ if (ic.wait_update == true)
{
- if (target.mim_ignore_focus_out)
- {
- Xex.Log ('ignore focus_out in ' + target.tagName);
- // Ignore this event which is caused by setSelectionRange ().
- target.mim_ignore_focus_out = false;
- event.preventDefault ();
- }
- else
- {
- Xex.Log ('focus_out in ' + target.tagName);
- if (! MIM.get_range (target, ic))
- ic.reset ();
- ic.Filter (MIM.Key.FocusOut);
- // Ignore further focus-out caused by setSelectionRange ().
- target.mim_ignore_focus_in = true;
- target.mim_ignore_focus_out = true;
- MIM.focus_ignore_target = target;
- MIM.update (target, ic);
- setTimeout (MIM.cancel_ignore_focus, 100);
- }
+ Xex.Log ("Focus out " + target.tagName + ' IGNORED');
+ event.preventDefault ();
+ return false;
}
+ Xex.Log ("Focus out " + target.tagName);
+ ic.Filter (MIM.Key.FocusOut);
+ ic.wait_update = true;
+ MIM.update (target, ic, true);
+ setTimeout (reset_update, 1000);
};
MIM.keydown = function (event)
Xex.Log ("filtering " + ic.key);
try {
var result = ic.Filter (ic.key);
+ Xex.Log ("result = " + result);
} catch (e) {
- Xex.Log ('Error;' + e);
+ Xex.Log ('Error:' + e);
throw (e);
}
MIM.update (target, ic);
list = lang_category[cat][lang].list;
if (! list)
list = lang_category[cat][lang].list = {};
- break;
+ for (name in MIM.imlist[lang])
+ list[name] = MIM.imlist[lang][name];
}
- if (list)
- for (name in MIM.imlist[lang])
- list[name] = MIM.imlist[lang][name];
- else
+ if (! list)
for (name in MIM.imlist[lang])
Xex.Log ('no category ' + lang + '-' + name);
}
li.style.top = '0px';
li.style.listStyle = 'none';
li.menu_level = level;
- li.appendChild (document.createTextNode (text));
+ var nobr = document.createElement ('nobr');
+ nobr.innerHTML = text;
+ li.appendChild (nobr);
return li;
}