aboutsummaryrefslogtreecommitdiffstats
path: root/migemo-find.js
blob: 33d935dd81b1e3ed77869517bca271a2af470e9d (plain)
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
var PLUGIN_INFO =
<VimperatorPlugin>
<name>{NAME}</name>
<description>Replace default search to migemo.</description>
<description lang="ja">標準の検索を XUL/Migemo に置き換えます</description>
<minVersion>2.0pre</minVersion>
<maxVersion>2.0</maxVersion>
<updateURL>http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk/migemo-find.js</updateURL>
<author mail="hotchpotch@gmail.com" homepage="http://d.hatena.ne.jp/secondlife/">Yuichi Tateno</author>
<license>MIT</license>
<version>0.1.0</version>
<detail lang="ja"><![CDATA[
標準の / などの検索を XUL/Migemo 検索に置き換えます
同等の機能を持つプラグインとして migemize_find がありますが
migemo-find.js  pIXMigemoFind が提供している XUL/Migemo のインターフェイスを直接利用しています

== ToDo ==

- migemo 正規表現でマッチしたパターンすべてにきちんとハイライト
-- 現状は最初にマッチした文字列のみハイライトされる

== ChangeLog ==

- 0.1.0
-- 検索開始文字の先頭が \ なら通常の検索を行うmigemo りたくない時など用に

]]></detail>
</VimperatorPlugin>;

liberator.plugins.migemoFind = (function() {
    let p = function(m) Application.console.log(m);

    let evalWithContext = function(func, context) {
        let str;
        let fstr = func.toString();
        if (fstr.indexOf('function () {') == 0) {
            str = fstr.replace(/.*?{([\s\S]+)}.*?/m, "$1");
        } else {
            str = '(' + fstr + ')()';
        }
        return liberator.eval(str, context);
    }

    var XMigemoFind;
    try {
        XMigemoFind = Cc['@piro.sakura.ne.jp/xmigemo/find;1']
                                .getService(Ci.pIXMigemoFind);
    } catch(ex if ex instanceof TypeError){}

    if (!XMigemoFind) {
        liberator.echoerr("XUL/Migemo not found. You should be install XUL/Migemo.");
        return;
    }

    // for 2.1pre
    if (typeof search == "undefined") {
	search = finder;
    }
    search.migemo = XMigemoFind.wrappedJSObject;
    search.migemo.target = window.gBrowser;

    if (!search._find)
        search._find = search.find;
    if (!search._findAgain)
        search._findAgain = search.findAgain;

    let setFound = function(f) {
        liberator.eval('found = ' + f.toString(), search._find);
    }

    if (!search.migemoFindEvnetListener) {
        search.migemoFindEvnetListener = search.migemo.document.addEventListener('XMigemoFindProgress', function(ev) {
            if (!ev.foundTerm) {
                liberator.echoerr("E486: Pattern not found: " + ev.findTerm, commandline.FORCE_SINGLELINE);
                setFound(false);
            } else {
                setFound(true);
            }
        }, false);
    }

    evalWithContext(function () {
       search.find = function (str) {
           if (str.indexOf('\\') == 0) {
               search.migemo.disable = true;
               search._find(str.substr(1));
           } else {
               search.migemo.disable = false;
               search.migemo.target = window.gBrowser;
               search.migemo.find(false, str, options["linksearch"]);
               searchString = searchPattern = search.migemo.lastFoundWord;
           }
       }
    }, search._find);

    evalWithContext(function () {
       search.findAgain = function (reverse) {
           let migemo = search.migemo;
           if (migemo.disable) {
               search._findAgain(reverse);
           } else {
               (!reverse) ? migemo.findNext(options["linksearch"]) : migemo.findPrevious(options["linksearch"]);
           }
       }
    }, search._findAgain);
    return this;
})();


an class="nx">login : '/sessions', id : 'session[username_or_email]', pw : 'session[password]', ex : ['authenticity_token'], exhost : 'https://twitter.com', logout : '/sessions/destroy', jump : '/', }, tumblr : { host : 'http://www.tumblr.com', login : '/login', id : 'email', pw : 'password', logout : '/logout', jump : '/dashboard', }, }; function init() { var rcServices = liberator.globalVariables.accountSwitcherServices; rcServices = !rcServices ? [] : rcServices; // loginmultiaccounts でログインするアカウントの読み込み loginServices = liberator.globalVariables.accountSwitcherLoginServices; loginServices = !loginServices ? [] : loginServices; for (var key in _services) if (_services.hasOwnProperty(key)) services[key] = _services[key]; for (var key in rcServices) if (rcServices.hasOwnProperty(key)) { var s = rcServices[key]; if (services[key] == null) services[key] = s; else { for (var k in s) if (s.hasOwnProperty(k)) { services[key][k] = s[k]; } } } var hosts = [key for (key in services)]; for (var i in hosts) { var host = hosts[i]; if (isFirst) nowLogin[host] = ''; var logins = manager.findLogins({}, services[host].host, "", null); var ignoreAccounts = liberator.globalVariables.accountSwitcherIngnoreAccounts; for (var i = 0; i < logins.length; i++) { var login = logins[i]; var usernameAndService = [login.username, host].join('@'); if (!!ignoreAccounts && ignoreAccounts.indexOf(usernameAndService) != -1) continue; accounts[usernameAndService] = {}; var a = accounts[usernameAndService]; a.username = login.username; a.password = login.password; a.host = host; } } isFirst = false; } function changeAccount(user) { var username = accounts[user].username; var password = accounts[user].password; var params = []; var service = services[accounts[user].host]; if (service.host == null || service.logout == null) return; if (!!service.params) params = service.params; var req = new XMLHttpRequest(); var url = (service.logout.indexOf('http') != 0) ? service.host + service.logout : service.logout; req.open("POST", url, true); req.onload = function(e) { var url = (service.login.indexOf('http') != 0) ? service.host + service.login : service.login; var ex = service.ex; if (!!ex) { var res; if (!!service.exhost) { res = util.httpGet(service.exhost); } else { res = util.httpGet(url); } for (var i = 0, length = ex.length; i < length; i++) { var value = ex[i]; if (value.indexOf('=') > 0) { params.push(value); } else { res.responseText.match(new RegExp('<([^<>]*?name=\"' + value + '\"[^<>]*?)>')); RegExp.$1.match(/value=\"([\w-]+)\"/); params.push(value + '=' + encodeURIComponent(RegExp.$1)); } } } if (service.login == null || service.id == null || service.pw == null) return; var req = new XMLHttpRequest(); req.open("POST", url, true); req.onload = function(e) { if (service.jump != null) { var url = (service.jump.indexOf('http') == -1) ? service.host + service.jump : service.jump; if (!!liberator.globalVariables.accountSwitcherOpenNewTab && window.content.location.href != 'about:blank') { liberator.open(url, liberator.NEW_BACKGROUND_TAB); } else { window.content.location.href = url; } } else if(content.location.href != 'about:blank') { window.content.location.reload(); } var needle = '.hatena.ne.jp'; if (service.host.toLowerCase().lastIndexOf(needle) == service.host.length - needle.length) { img.setAttribute('src', 'http://www.hatena.ne.jp/users/' + username.substr(0, 2) + '/' + username + '/profile_s.gif'); img.setAttribute('tooltiptext', 'id:' + username); if (!document.getElementById('account_switcher_pannel')) { if (afterSLine != null) { statusBar.insertBefore(sbPannel, afterSLine); } else { statusBar.appendChild(sbPannel); } } } }; req.onerror = function(e) { liberator.echoerr('Login error in account_switcher.js'); }; req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); params.push(service.id + '=' + encodeURIComponent(username)); params.push(service.pw + '=' + encodeURIComponent(password)); req.send(params.join('&')); nowLogin[user.substr(user.lastIndexOf('@') + 1)] = user; }; req.onerror = function(e) { liberator.echoerr('Logout error in account_switcher.js'); }; req.send(null); } function loginMultiAccounts() { for (var i = 0, length = loginServices.length; i < length; i++) { for (var key in accounts) if (accounts.hasOwnProperty(key)) { if (key == loginServices[i]) { changeAccount(key); continue; } } } } commands.addUserCommand(["loginmultiaccounts"], "Login multi accounts", function() { init(); loginMultiAccounts(); } ); commands.addUserCommand(["account"], "Change Account", function(args) { if (!args) { liberator.echo("Usage: account {username}@{servicename}"); } else { var user = args[args.length - 1]; if (!user) return; changeAccount(user); } }, { completer: function(context, args) { init(); context.title = ["Account", "Service"]; for (var service in nowLogin) if (nowLogin.hasOwnProperty(service)) { var username = nowLogin[service]; if (username != '') delete(accounts[username]); } var compls = [[key, accounts[key].host] for (key in accounts) if (accounts.hasOwnProperty(key))]; if (args.length > 0) { for (var i = 0; i < args.length; i++) { var user = args[i]; if (user != '') { compls = compls.filter(function(c) c[0].indexOf(user) != -1); } } } return [0, compls]; } } ); })(); // vim:sw=4 ts=4 et: