aboutsummaryrefslogtreecommitdiffstats
path: root/scalapi.js
blob: 55a3434c392a4430f3448e704a65705c9bafddc9 (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
var PLUGIN_INFO =
<VimperatorPlugin>
<name>{NAME}</name>
<description>Scala API document</description>
<description lang="ja">Scala API を検索し補完します</description>
<minVersion>2.0pre</minVersion>
<maxVersion>2.0pre</maxVersion>
<updateURL>http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk/scalapi.js</updateURL>
<author mail="hotchpotch@gmail.com" homepage="http://tako3.net/http://d.hatena.ne.jp/secondlife/">Yuichi Tateno</author>
<license>MPL 1.1/GPL 2.0/LGPL 2.1</license>
<version>0.1</version>
<detail><![CDATA[
Scala  API を検索し保管し該当のページを開きます

:sc[alapi][!] List[tab]

引数には正規表現も利用できます
]]></detail>
</VimperatorPlugin>;

(function() {
var p = function(arg) {
    Application.console.log(arg);
    // liberator.log(arg);
};

var scalaApiURL = liberator.globalVariables.scalaApiURL || 'http://www.scala-lang.org/docu/files/api/';
if (!liberator.globalVariables.scalaApiCache) {
    let xhr = new XMLHttpRequest();
    let regex = new RegExp('<a href="scala/([^.]+).html" target="contentFrame">([^.]+)</a></li>', 'g');
    xhr.onreadystatechange = function() {
        if (xhr.readyState == 4) {
            if (xhr.status == 200) {
                let text = xhr.responseText;
                let res = [];
                res.hashMap = {};
                text.replace(regex, function(m) {
                    let path = RegExp.$1;
                    let name = path.replace('$object', '');
                    name = name.replace(/\//g, '.');
                    res.push([name, path]);
                    res.hashMap[name] = path;
                });
                liberator.globalVariables.scalaApiCache = res;
            } else {
                liberator.echoerr('Scala API : XHR Error: ' + xhr.statusText);
                // throw new Error(xhr.statusText);
            }
        }
    };
    xhr.open('GET', scalaApiURL + 'all-classes.html', true);
    xhr.send(null);
}

commands.addUserCommand(
    liberator.globalVariables.scalaApiCommands || ['scalapi', 'sc'],
    'Scala API Search',
    function(args) {
        var name = (args.string || '');
        var url = (name && liberator.globalVariables.scalaApiCache.hashMap[name]) ? scalaApiURL + 'scala/' + liberator.globalVariables.scalaApiCache.hashMap[name] + '.html' : scalaApiURL + 'index.html';
        liberator.open(url, args.bang ? liberator.NEW_TAB : null);
    }, {
        completer: function(context) {
            context.title = ['API Name', 'API'];
            var word = context.filter;// .toUpperCase();
            /*
            if (word.indexOf('.') >= 0) {
                let regex = word.split(/\.+/).map(function(i) i + '[^.]*').join('.');
                p(regex);
                regex = new RegExp('^' + regex.replace(/\[\^\.\]\*$/, ''));
                p(regex);
                context.filters = [function(item) regex.test(item.item[0])];
            } else {
                context.filters = [function(item) item.item[0].toUpperCase().indexOf(word) != -1];
            }
            */
            try {
                var regex = new RegExp(word, 'i');
                context.filters = [function(item) regex.test(item.item[0])];
            } catch(e) {
                var word = context.filter.toUpperCase();
                context.filters = [function(item) item.item[0].toUpperCase().indexOf(word) != -1];
            }
            context.completions = liberator.globalVariables.scalaApiCache || [];
        },
        argCount: '*',
        bang: true
    },
    true
);

})();

>1); if (SplitBrowser.activeBrowser == getBrowser()){ if (count > 0){ bs[count-1].browser.contentWindow.focus(); } else if (count < 0){ bs[length + count].browser.contentWindow.focus(); } else { return; } } else { var id = SplitBrowser.activeSubBrowser.id; for (var i=0; i<length; i++){ if (bs[i].id == id){ count = (count + i + 1) % (length + 1); if (count > 0){ bs[count-1].browser.contentWindow.focus(); } else if (count < 0){ bs[length + count].browser.contentWindow.focus(); } else { getBrowser().contentWindow.focus(); } return true; } } } } } //}}} var commandExtra = { completer: function(filter) completion.url(filter), options: [ [['-l','-left'], commands.OPTION_NOARG], [['-r','-right'], commands.OPTION_NOARG], [['-t','-top'], commands.OPTION_NOARG], [['-b','-bottom'], commands.OPTION_NOARG] ], argCount: "*" }; /* ---------------------------------------------- * Commands * --------------------------------------------*/ commands.addUserCommand(['sp[lit]'], 'split browser', //{{{ function(args){ liberator.plugins.splitBrowser.openSubBrowser(args, SplitBrowser.POSITION_TOP); }, commandExtra ); //}}} commands.addUserCommand(['vs[plit]'], 'split browser', //{{{ function(args){ liberator.plugins.splitBrowser.openSubBrowser(args, SplitBrowser.POSITION_RIGHT); }, commandExtra ); //}}} commands.addUserCommand(['on[ly]'], 'Close or gather all subbrowsers', //{{{ function(args){ if (SplitBrowser.browsers.length == 0) { liberator.echoerr('SubBrowser is none'); return; } if (args == '-g') { SplitBrowser.gatherSubBrowsers(); } else { SplitBrowser.removeAllSubBrowsers(); } } ); //}}} /* ---------------------------------------------- * Mappings * --------------------------------------------*/ mappings.addUserMap([modes.NORMAL],['s'], 'SplitBrowser motion Map', //{{{ function(key, count){ gBrowser = SplitBrowser.activeBrowser; try { var map = mappings.get(modes.NORMAL, key) map.execute(null, count); } catch(e) { liberator.log(e); } finally { gBrowser = document.getElementById('content'); } },{ flags: Mappings.flags.MOTION + Mappings.flags.COUNT, rhs: 'Motion map for SplitBrowser' } ); //}}} mappings.addUserMap([modes.NORMAL], ['<C-w>'], 'select subbrowser', //{{{ function(count, key){ if (/[1-9]/.test(key)){ focusSwitch(parseInt(key), true); return; } switch (key){ case '0': case '$': focusSwitch(key); break; case 'h': //FIXME: How to get subbrowser of relative position ? case 'j': case '<C-w>': case 'w': focusSwitch(count > 0 ? count : 1); break; case 'k': case 'l': case 'W': forcusSwitch('-' + (count > 0 ? count : 1)); break; case 'd': liberator.plugins.splitBrowser.closeSubBrowser(); break; case '<C-v>': liberator.plugins.splitBrowser.openSubBrowser(buffer.URL,SplitBrowser.POSITION_RIGHT); break; case '<C-s>': liberator.plugins.splitBrowser.openSubBrowser(buffer.URL,SplitBrowser.POSITION_TOP); break; } },{ flags: Mappings.flags.COUNT + Mappings.flags.ARGUMENT, rhs: 'select subbrowser' } ); //}}} /** * Overwrite liberator.open for SplitBrowser * @see liberator.js::vimperaotr.open */ liberator.open = function(urls, where, force){ //{{{ if (typeof urls == 'string') urls = util.stringToURLArray(urls); if (urls.length > 20 && !force){ commandline.input("This will open " + urls.length + " new tabs. Would you like to continue? (yes/[no])", function (resp) { if (resp && resp.match(/^y(es)?$/i)) liberator.open(urls, where, true); }); return true; } if (urls.length == 0) return false; if (liberator.forceNewTab && liberator.has("tabs")){ where = liberator.NEW_TAB; } else if (!where || !liberator.has("tabs")){ where = liberator.CURRENT_TAB; } var url = typeof urls[0] == 'string' ? urls[0] : urls[0][0]; var postdata = typeof urls[0] == 'string' ? null : urls[0][1]; var whichwindow = window; var activeBrowser = SplitBrowser.activeBrowser; switch (where) { case liberator.CURRENT_TAB: activeBrowser.loadURIWithFlags(url, null, null, null, postdata); break; case liberator.NEW_TAB: var firsttab = activeBrowser.addTab(url, null, null, postdata); activeBrowser.selectedTab = firsttab; break; case liberator.NEW_BACKGROUND_TAB: activeBrowser.addTab(url, null, null, postdata); break; case liberator.NEW_WINDOW: window.open(); var wm = Components.classes["@mozilla.org/appshell/window-mediator;1"] .getService(Components.interfaces.nsIWindowMediator); whichwindow = vm.getMostRecentWindow('navigator:browser'); whichwindow.loadURI(url, null, postdata); break; default: liberator.echoerr("Exxx: Invalid 'where' directive in liberator.open(...)"); return false; } if (!liberator.has("tabs")) return true; for (var i=1, l=urls.length; i < l; i++){ url = typeof urls[i] == 'string' ? urls[i] : urls[i][0]; postdata = typeof urls[i] == 'string' ? null : urls[i][1]; whichwindow.SplitBrowser.activeBrowser.addTab(url, null, null, postdata); } return true; }; //}}} var manager = { splitBrowserId: SplitBrowserAppID, /** * create new subBrowser and load url * @param {Object} args command aruguments * @param {Number} defPosition default split direction */ openSubBrowser: function(args, defPosition){ var url; var urls = []; var position = defPosition || SplitBrowser.POSITION_TOP; position = getPositionForOpen(args) || position; if (args.length > 0){ urls = util.stringToURLArray(args.join(', ')); if (urls.length == 0) { url = buffer.URL; } else { url = urls[0]; urls.shift(); } } else { url = buffer.URL; } var subBrowser = SplitBrowser.addSubBrowser(url, null, position); subBrowser.addEventListener('load',function(){ subBrowser.removeEventListener('load',arguments.callee,true); subBrowser.browser.contentWindow.focus(); },true); urls.forEach(function(url){ subBrowser.browser.addTab(url, null, null, null); }); return subBrowser; }, closeSubBrowser: function(){ var b = SplitBrowser.activeBrowser; if (b.mTabs.length > 1){ b.removeTab(b.mCurrentTab); } else { if (b === getBrowser()){ liberator.open('about:blank', liberator.NEW_BACKGROUND_TAB); getBrowser().removeTab(gBrowser.mCurrentTab); } else { SplitBrowser.activeBrowserCloseWindow(); } } } }; return manager; })(); })(); // vim:fdm=marker sw=4 ts=4 et: