var PLUGIN_INFO = {NAME} Replace default search to migemo. 標準の検索を XUL/Migemo に置き換えます 2.0pre 2.0 http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk/migemo-find.js Yuichi Tateno MIT 0.1.0 ; 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; })(); >
blob: 2284160499033f68e7120d9f2284e449efc03d09 (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
110
111
112
// PLUGIN_INFO//{{{
var PLUGIN_INFO =
<VimperatorPlugin>
  <name>{NAME}</name>
  <description>controls autopagerize</description>
  <author mail="konbu.komuro@gmail.com" homepage="http://d.hatena.ne.jp/hogelog/">hogelog</author>
  <version>0.0.1</version>
  <maxVersion>2.0pre</maxVersion>
  <updateURL>http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk/autopagerize_controll.js</updateURL>
  <detail><![CDATA[
== Options ==
enable mapping key like
>||
  let g:autopagerize_prevmap = "J"
  let g:autopagerize_nextmap = "K"
||<

== Commands ==
autopagerize_next:
    paging next page
autopagerize_prev:
    paging prev page

== TODO ==

  ]]></detail>
</VimperatorPlugin>;
//}}}
(function() {

var libly = liberator.plugins.libly;
var $U = libly.$U;
var prevMap = liberator.globalVariables.autopagerize_prevmap;
var nextMap = liberator.globalVariables.autopagerize_nextmap;

var pager = {
    modes: [modes.NORMAL, modes.VISUAL],
    next: function(doc, count) {
        var curPage = pager.getCurrentPage(doc);
        liberator.reportError(curPage);
        pager.paging(doc, Math.floor(curPage+count));
    },
    prev: function(doc, count) {
        var curPage = pager.getCurrentPage(doc);
        liberator.reportError(curPage);
        pager.paging(doc, Math.round(curPage-count));
    },
    paging: function(doc, page) {
        liberator.reportError(page);
        var win = doc.defaultView;
        if (page <= 1) {
            win.scrollTo(0, 0);
        } else if (!pager.focusPageNav(doc, page)) {
            win.scrollTo(0, win.scrollMaxY);
        }
    },
    focusPageNav: function(doc, page) {
        var xpath = '//*[@class="autopagerize_page_info" and child::a[contains(text(), "'+page+'")]]';
        var [ elem ] = $U.getNodesFromXPath(xpath, doc);
        var win = doc.defaultView;
        if (elem) {
            let p = $U.getElementPosition(elem);
            win.scrollTo(0, p.top);
            return true;
        }
        return false;
    },
    getCurrentPage: function(doc) {
        var xpath = '//*[@class="autopagerize_page_info"]';
        var markers = $U.getNodesFromXPath(xpath, doc);
        var win = doc.defaultView;
        var curPos = win.scrollY;

        // top of page
        if (curPos <= 0) return 1.0;

        // bottom of page
        if (curPos >= win.scrollMaxY) return 1.0 + markers.length;

        // return n.5 if between n and n+1
        var page = 1.0;
        for (let i = 0, len = markers.length; i < len; i++) {
            let p = $U.getElementPosition(markers[i]);
            if (curPos == p.top) return page+1;
            if (curPos < p.top) return page+0.5;
            ++page;
        }
        return page+0.5;
    },
};
commands.addUserCommand(["nextpage"], "Autopagerize next page",
    function(args)
        pager.next(window.content.document, args.length>0 ? args[0] : 1));
commands.addUserCommand(["prevpage"], "Autopagerize prev page",
    function(args)
        pager.prev(window.content.document, args.length>0 ? args[0] : 1));

if (nextMap) {
    mappings.addUserMap(pager.modes, [nextMap], "Autopagerize next page",
            function(count)
                pager.next(window.content.document, count>0 ? count : 1),
            {flags: Mappings.flags.COUNT});
}
if (prevMap) {
    mappings.addUserMap(pager.modes, [prevMap], "Autopagerize prev page",
            function(count)
                pager.prev(window.content.document, count>0 ? count : 1),
            {flags: Mappings.flags.COUNT});
}

})();
// vim: set fdm=marker sw=4 ts=4 et: