jruby_excelcom 0.0.1-java

Sign up to get free protection for your applications and to get access to all the features.
Files changed (72) hide show
  1. checksums.yaml +7 -0
  2. data/.//jruby_excelcom.gemspec +13 -0
  3. data/LICENSE +201 -0
  4. data/doc/ExcelColor.html +95 -0
  5. data/doc/ExcelConnection.html +709 -0
  6. data/doc/JavaExcelcom.html +95 -0
  7. data/doc/LICENSE.html +283 -0
  8. data/doc/MiniTest.html +95 -0
  9. data/doc/Object.html +153 -0
  10. data/doc/Time.html +95 -0
  11. data/doc/Workbook.html +520 -0
  12. data/doc/Worksheet.html +1111 -0
  13. data/doc/created.rid +12 -0
  14. data/doc/css/fonts.css +167 -0
  15. data/doc/css/rdoc.css +590 -0
  16. data/doc/fonts/Lato-Light.ttf +0 -0
  17. data/doc/fonts/Lato-LightItalic.ttf +0 -0
  18. data/doc/fonts/Lato-Regular.ttf +0 -0
  19. data/doc/fonts/Lato-RegularItalic.ttf +0 -0
  20. data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
  21. data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
  22. data/doc/images/add.png +0 -0
  23. data/doc/images/arrow_up.png +0 -0
  24. data/doc/images/brick.png +0 -0
  25. data/doc/images/brick_link.png +0 -0
  26. data/doc/images/bug.png +0 -0
  27. data/doc/images/bullet_black.png +0 -0
  28. data/doc/images/bullet_toggle_minus.png +0 -0
  29. data/doc/images/bullet_toggle_plus.png +0 -0
  30. data/doc/images/date.png +0 -0
  31. data/doc/images/delete.png +0 -0
  32. data/doc/images/find.png +0 -0
  33. data/doc/images/loadingAnimation.gif +0 -0
  34. data/doc/images/macFFBgHack.png +0 -0
  35. data/doc/images/package.png +0 -0
  36. data/doc/images/page_green.png +0 -0
  37. data/doc/images/page_white_text.png +0 -0
  38. data/doc/images/page_white_width.png +0 -0
  39. data/doc/images/plugin.png +0 -0
  40. data/doc/images/ruby.png +0 -0
  41. data/doc/images/tag_blue.png +0 -0
  42. data/doc/images/tag_green.png +0 -0
  43. data/doc/images/transparent.png +0 -0
  44. data/doc/images/wrench.png +0 -0
  45. data/doc/images/wrench_orange.png +0 -0
  46. data/doc/images/zoom.png +0 -0
  47. data/doc/index.html +103 -0
  48. data/doc/jruby_excelcom_gemspec.html +98 -0
  49. data/doc/js/darkfish.js +161 -0
  50. data/doc/js/jquery.js +4 -0
  51. data/doc/js/navigation.js +142 -0
  52. data/doc/js/navigation.js.gz +0 -0
  53. data/doc/js/search.js +109 -0
  54. data/doc/js/search_index.js +1 -0
  55. data/doc/js/search_index.js.gz +0 -0
  56. data/doc/js/searcher.js +228 -0
  57. data/doc/js/searcher.js.gz +0 -0
  58. data/doc/table_of_contents.html +337 -0
  59. data/lib/jars/excelcom-0.0.5.jar +0 -0
  60. data/lib/jars/jna-4.4.0.jar +0 -0
  61. data/lib/jars/jna-platform-4.4.0.jar +0 -0
  62. data/lib/jruby_excelcom/excel_connection.rb +81 -0
  63. data/lib/jruby_excelcom/workbook.rb +46 -0
  64. data/lib/jruby_excelcom/worksheet.rb +136 -0
  65. data/lib/jruby_excelcom.rb +22 -0
  66. data/test/resources/test.xlsx +0 -0
  67. data/test/resources/test2.xlsx +0 -0
  68. data/test/test_helper.rb +4 -0
  69. data/test/unit/excel_connection_spec.rb +38 -0
  70. data/test/unit/workbook_spec.rb +41 -0
  71. data/test/unit/worksheet_spec.rb +100 -0
  72. metadata +114 -0
@@ -0,0 +1,142 @@
1
+ /*
2
+ * Navigation allows movement using the arrow keys through the search results.
3
+ *
4
+ * When using this library you will need to set scrollIntoView to the
5
+ * appropriate function for your layout. Use scrollInWindow if the container
6
+ * is not scrollable and scrollInElement if the container is a separate
7
+ * scrolling region.
8
+ */
9
+ Navigation = new function() {
10
+ this.initNavigation = function() {
11
+ var _this = this;
12
+
13
+ $(document).keydown(function(e) {
14
+ _this.onkeydown(e);
15
+ }).keyup(function(e) {
16
+ _this.onkeyup(e);
17
+ });
18
+
19
+ this.navigationActive = true;
20
+ }
21
+
22
+ this.setNavigationActive = function(state) {
23
+ this.navigationActive = state;
24
+ this.clearMoveTimeout();
25
+ }
26
+
27
+ this.onkeyup = function(e) {
28
+ if (!this.navigationActive) return;
29
+
30
+ switch(e.keyCode) {
31
+ case 37: //Event.KEY_LEFT:
32
+ case 38: //Event.KEY_UP:
33
+ case 39: //Event.KEY_RIGHT:
34
+ case 40: //Event.KEY_DOWN:
35
+ this.clearMoveTimeout();
36
+ break;
37
+ }
38
+ }
39
+
40
+ this.onkeydown = function(e) {
41
+ if (!this.navigationActive) return;
42
+ switch(e.keyCode) {
43
+ case 37: //Event.KEY_LEFT:
44
+ if (this.moveLeft()) e.preventDefault();
45
+ break;
46
+ case 38: //Event.KEY_UP:
47
+ if (e.keyCode == 38 || e.ctrlKey) {
48
+ if (this.moveUp()) e.preventDefault();
49
+ this.startMoveTimeout(false);
50
+ }
51
+ break;
52
+ case 39: //Event.KEY_RIGHT:
53
+ if (this.moveRight()) e.preventDefault();
54
+ break;
55
+ case 40: //Event.KEY_DOWN:
56
+ if (e.keyCode == 40 || e.ctrlKey) {
57
+ if (this.moveDown()) e.preventDefault();
58
+ this.startMoveTimeout(true);
59
+ }
60
+ break;
61
+ case 13: //Event.KEY_RETURN:
62
+ if (this.$current)
63
+ e.preventDefault();
64
+ this.select(this.$current);
65
+ break;
66
+ }
67
+ if (e.ctrlKey && e.shiftKey) this.select(this.$current);
68
+ }
69
+
70
+ this.clearMoveTimeout = function() {
71
+ clearTimeout(this.moveTimeout);
72
+ this.moveTimeout = null;
73
+ }
74
+
75
+ this.startMoveTimeout = function(isDown) {
76
+ if (!$.browser.mozilla && !$.browser.opera) return;
77
+ if (this.moveTimeout) this.clearMoveTimeout();
78
+ var _this = this;
79
+
80
+ var go = function() {
81
+ if (!_this.moveTimeout) return;
82
+ _this[isDown ? 'moveDown' : 'moveUp']();
83
+ _this.moveTimout = setTimeout(go, 100);
84
+ }
85
+ this.moveTimeout = setTimeout(go, 200);
86
+ }
87
+
88
+ this.moveRight = function() {
89
+ }
90
+
91
+ this.moveLeft = function() {
92
+ }
93
+
94
+ this.move = function(isDown) {
95
+ }
96
+
97
+ this.moveUp = function() {
98
+ return this.move(false);
99
+ }
100
+
101
+ this.moveDown = function() {
102
+ return this.move(true);
103
+ }
104
+
105
+ /*
106
+ * Scrolls to the given element in the scrollable element view.
107
+ */
108
+ this.scrollInElement = function(element, view) {
109
+ var offset, viewHeight, viewScroll, height;
110
+ offset = element.offsetTop;
111
+ height = element.offsetHeight;
112
+ viewHeight = view.offsetHeight;
113
+ viewScroll = view.scrollTop;
114
+
115
+ if (offset - viewScroll + height > viewHeight) {
116
+ view.scrollTop = offset - viewHeight + height;
117
+ }
118
+ if (offset < viewScroll) {
119
+ view.scrollTop = offset;
120
+ }
121
+ }
122
+
123
+ /*
124
+ * Scrolls to the given element in the window. The second argument is
125
+ * ignored
126
+ */
127
+ this.scrollInWindow = function(element, ignored) {
128
+ var offset, viewHeight, viewScroll, height;
129
+ offset = element.offsetTop;
130
+ height = element.offsetHeight;
131
+ viewHeight = window.innerHeight;
132
+ viewScroll = window.scrollY;
133
+
134
+ if (offset - viewScroll + height > viewHeight) {
135
+ window.scrollTo(window.scrollX, offset - viewHeight + height);
136
+ }
137
+ if (offset < viewScroll) {
138
+ window.scrollTo(window.scrollX, offset);
139
+ }
140
+ }
141
+ }
142
+
Binary file
data/doc/js/search.js ADDED
@@ -0,0 +1,109 @@
1
+ Search = function(data, input, result) {
2
+ this.data = data;
3
+ this.$input = $(input);
4
+ this.$result = $(result);
5
+
6
+ this.$current = null;
7
+ this.$view = this.$result.parent();
8
+ this.searcher = new Searcher(data.index);
9
+ this.init();
10
+ }
11
+
12
+ Search.prototype = $.extend({}, Navigation, new function() {
13
+ var suid = 1;
14
+
15
+ this.init = function() {
16
+ var _this = this;
17
+ var observer = function(e) {
18
+ switch(e.originalEvent.keyCode) {
19
+ case 38: // Event.KEY_UP
20
+ case 40: // Event.KEY_DOWN
21
+ return;
22
+ }
23
+ _this.search(_this.$input[0].value);
24
+ };
25
+ this.$input.keyup(observer);
26
+ this.$input.click(observer); // mac's clear field
27
+
28
+ this.searcher.ready(function(results, isLast) {
29
+ _this.addResults(results, isLast);
30
+ })
31
+
32
+ this.initNavigation();
33
+ this.setNavigationActive(false);
34
+ }
35
+
36
+ this.search = function(value, selectFirstMatch) {
37
+ value = jQuery.trim(value).toLowerCase();
38
+ if (value) {
39
+ this.setNavigationActive(true);
40
+ } else {
41
+ this.setNavigationActive(false);
42
+ }
43
+
44
+ if (value == '') {
45
+ this.lastQuery = value;
46
+ this.$result.empty();
47
+ this.$result.attr('aria-expanded', 'false');
48
+ this.setNavigationActive(false);
49
+ } else if (value != this.lastQuery) {
50
+ this.lastQuery = value;
51
+ this.$result.attr('aria-busy', 'true');
52
+ this.$result.attr('aria-expanded', 'true');
53
+ this.firstRun = true;
54
+ this.searcher.find(value);
55
+ }
56
+ }
57
+
58
+ this.addResults = function(results, isLast) {
59
+ var target = this.$result.get(0);
60
+ if (this.firstRun && (results.length > 0 || isLast)) {
61
+ this.$current = null;
62
+ this.$result.empty();
63
+ }
64
+
65
+ for (var i=0, l = results.length; i < l; i++) {
66
+ var item = this.renderItem.call(this, results[i]);
67
+ item.setAttribute('id', 'search-result-' + target.childElementCount);
68
+ target.appendChild(item);
69
+ };
70
+
71
+ if (this.firstRun && results.length > 0) {
72
+ this.firstRun = false;
73
+ this.$current = $(target.firstChild);
74
+ this.$current.addClass('search-selected');
75
+ }
76
+ if (jQuery.browser.msie) this.$element[0].className += '';
77
+
78
+ if (isLast) this.$result.attr('aria-busy', 'false');
79
+ }
80
+
81
+ this.move = function(isDown) {
82
+ if (!this.$current) return;
83
+ var $next = this.$current[isDown ? 'next' : 'prev']();
84
+ if ($next.length) {
85
+ this.$current.removeClass('search-selected');
86
+ $next.addClass('search-selected');
87
+ this.$input.attr('aria-activedescendant', $next.attr('id'));
88
+ this.scrollIntoView($next[0], this.$view[0]);
89
+ this.$current = $next;
90
+ this.$input.val($next[0].firstChild.firstChild.text);
91
+ this.$input.select();
92
+ }
93
+ return true;
94
+ }
95
+
96
+ this.hlt = function(html) {
97
+ return this.escapeHTML(html).
98
+ replace(/\u0001/g, '<em>').
99
+ replace(/\u0002/g, '</em>');
100
+ }
101
+
102
+ this.escapeHTML = function(html) {
103
+ return html.replace(/[&<>]/g, function(c) {
104
+ return '&#' + c.charCodeAt(0) + ';';
105
+ });
106
+ }
107
+
108
+ });
109
+
@@ -0,0 +1 @@
1
+ var search_data = {"index":{"searchIndex":["excelcolor","excelconnection","javaexcelcom","minitest","time","workbook","worksheet","active_workbook()","addworksheet()","add_worksheet()","border_color()","border_color=()","close()","connect()","content()","content=()","delete()","display_alerts=()","fill_color()","fill_color=()","font_color()","font_color=()","getactiveworkbook()","getbordercolor()","getcontent()","getfillcolor()","getfontcolor()","getname()","getname()","getversion()","getworksheet()","initialize_com()","name()","name()","name=()","new()","new()","new()","openworkbook()","open_workbook()","quit()","save()","saveas()","save_as()","setbordercolor()","setcontent()","setdisplayalerts()","setfillcolor()","setfontcolor()","setname()","setvisible()","set_border_color()","set_content()","set_fill_color()","set_font_color()","uninitialize_com()","version()","visible=()","workbook()","worksheet()","license","jruby_excelcom.gemspec"],"longSearchIndex":["excelcolor","excelconnection","javaexcelcom","minitest","time","workbook","worksheet","excelconnection#active_workbook()","workbook#addworksheet()","workbook#add_worksheet()","worksheet#border_color()","worksheet#border_color=()","workbook#close()","excelconnection::connect()","worksheet#content()","worksheet#content=()","worksheet#delete()","excelconnection#display_alerts=()","worksheet#fill_color()","worksheet#fill_color=()","worksheet#font_color()","worksheet#font_color=()","excelconnection#getactiveworkbook()","worksheet#getbordercolor()","worksheet#getcontent()","worksheet#getfillcolor()","worksheet#getfontcolor()","workbook#getname()","worksheet#getname()","excelconnection#getversion()","workbook#getworksheet()","excelconnection::initialize_com()","workbook#name()","worksheet#name()","worksheet#name=()","excelconnection::new()","workbook::new()","worksheet::new()","excelconnection#openworkbook()","excelconnection#open_workbook()","excelconnection#quit()","workbook#save()","workbook#saveas()","workbook#save_as()","worksheet#setbordercolor()","worksheet#setcontent()","excelconnection#setdisplayalerts()","worksheet#setfillcolor()","worksheet#setfontcolor()","worksheet#setname()","excelconnection#setvisible()","worksheet#set_border_color()","worksheet#set_content()","worksheet#set_fill_color()","worksheet#set_font_color()","excelconnection::uninitialize_com()","excelconnection#version()","excelconnection#visible=()","excelconnection#workbook()","workbook#worksheet()","",""],"info":[["ExcelColor","","ExcelColor.html","",""],["ExcelConnection","","ExcelConnection.html","",""],["JavaExcelcom","","JavaExcelcom.html","",""],["MiniTest","","MiniTest.html","",""],["Time","","Time.html","",""],["Workbook","","Workbook.html","",""],["Worksheet","","Worksheet.html","",""],["active_workbook","ExcelConnection","ExcelConnection.html#method-i-active_workbook","()","<p>gets the active workbook\n"],["addWorksheet","Workbook","Workbook.html#method-i-addWorksheet","(name)",""],["add_worksheet","Workbook","Workbook.html#method-i-add_worksheet","(name)","<p>adds and returns a worksheet to this workbook\n<p>name &mdash; name of new worksheet\n\n"],["border_color","Worksheet","Worksheet.html#method-i-border_color","(range)","<p>gets the border color of cells in range. Throws a\n<code>NullpointerException</code> if range contains multiple colors …\n"],["border_color=","Worksheet","Worksheet.html#method-i-border_color-3D","(hash)","<p>sets border color of cells in range\n<p>hash &mdash; must contain <code>:range</code> and <code>:color</code>\n\n"],["close","Workbook","Workbook.html#method-i-close","(save = false)","<p>closes this workbook\n<p>save &mdash; whether changes should be saved or not, default is <code>false</code>\n\n"],["connect","ExcelConnection","ExcelConnection.html#method-c-connect","(use_active_instance = false)","<p>see <code>new</code>\n<p>optional block possible, where <code>ExcelConnection#quit</code> gets\ncalled on blocks end e.g. <code>ExcelConnection::connect{|con|</code> …\n"],["content","Worksheet","Worksheet.html#method-i-content","(range = 'UsedRange')","<p>returns the content in range as a matrix, a vector or a single value,\ndepending on <code>range</code>&#39;s dimensions …\n"],["content=","Worksheet","Worksheet.html#method-i-content-3D","(hash)","<p>sets content in a range\n<p>hash &mdash; must contain <code>:range</code> and <code>:content</code>, e.g.\n<code>{:range =&gt; &#39;A1:A3&#39;, :content</code> …\n\n"],["delete","Worksheet","Worksheet.html#method-i-delete","()","<p>deletes this worksheet\n"],["display_alerts=","ExcelConnection","ExcelConnection.html#method-i-display_alerts-3D","(da)","<p>whether dialog boxes should show up or not (e.g. when saving and\noverwriting a file)\n"],["fill_color","Worksheet","Worksheet.html#method-i-fill_color","(range)","<p>gets the fill color of cells in range. Throws a\n<code>NullpointerException</code> if range contains multiple colors …\n"],["fill_color=","Worksheet","Worksheet.html#method-i-fill_color-3D","(hash)","<p>fills cells in range with color\n<p>hash &mdash; must contain <code>:range</code> and <code>:color</code>\n\n"],["font_color","Worksheet","Worksheet.html#method-i-font_color","(range)","<p>gets the font color of cells in range. Throws a\n<code>NullpointerException</code> if range contains multiple colors …\n"],["font_color=","Worksheet","Worksheet.html#method-i-font_color-3D","(hash)","<p>sets font color of cells in range\n<p>hash &mdash; must contain <code>:range</code> and <code>:color</code>\n\n"],["getActiveWorkbook","ExcelConnection","ExcelConnection.html#method-i-getActiveWorkbook","()",""],["getBorderColor","Worksheet","Worksheet.html#method-i-getBorderColor","(range)",""],["getContent","Worksheet","Worksheet.html#method-i-getContent","(range = 'UsedRange')",""],["getFillColor","Worksheet","Worksheet.html#method-i-getFillColor","(range)",""],["getFontColor","Worksheet","Worksheet.html#method-i-getFontColor","(range)",""],["getName","Workbook","Workbook.html#method-i-getName","()",""],["getName","Worksheet","Worksheet.html#method-i-getName","()",""],["getVersion","ExcelConnection","ExcelConnection.html#method-i-getVersion","()",""],["getWorksheet","Workbook","Workbook.html#method-i-getWorksheet","(name)",""],["initialize_com","ExcelConnection","ExcelConnection.html#method-c-initialize_com","()","<p>initializes com manually, not recommended! happens automatically when an\ninstance is created\n"],["name","Workbook","Workbook.html#method-i-name","()","<p>gets the name of this workbook\n"],["name","Worksheet","Worksheet.html#method-i-name","()","<p>gets the name of this worksheet\n"],["name=","Worksheet","Worksheet.html#method-i-name-3D","(name)","<p>sets the name of this worksheet\n"],["new","ExcelConnection","ExcelConnection.html#method-c-new","(use_active_instance = false)","<p>initializes com and connects to an excel instance\n<p>use_active_instance &mdash; whether an existing excel instance …\n\n"],["new","Workbook","Workbook.html#method-c-new","(java_wb)",""],["new","Worksheet","Worksheet.html#method-c-new","(java_ws)",""],["openWorkbook","ExcelConnection","ExcelConnection.html#method-i-openWorkbook","(file)",""],["open_workbook","ExcelConnection","ExcelConnection.html#method-i-open_workbook","(file)",""],["quit","ExcelConnection","ExcelConnection.html#method-i-quit","()","<p>quits the excel instance and uninitializes com\n"],["save","Workbook","Workbook.html#method-i-save","()","<p>saves this workbook\n"],["saveAs","Workbook","Workbook.html#method-i-saveAs","(path)",""],["save_as","Workbook","Workbook.html#method-i-save_as","(path)","<p>saves this workbook to a new location. Every further operations on this\nworkbook will happen to the newly …\n"],["setBorderColor","Worksheet","Worksheet.html#method-i-setBorderColor","(range, color)",""],["setContent","Worksheet","Worksheet.html#method-i-setContent","(range, content)",""],["setDisplayAlerts","ExcelConnection","ExcelConnection.html#method-i-setDisplayAlerts","(da)",""],["setFillColor","Worksheet","Worksheet.html#method-i-setFillColor","(range, color)",""],["setFontColor","Worksheet","Worksheet.html#method-i-setFontColor","(range, color)",""],["setName","Worksheet","Worksheet.html#method-i-setName","(name)",""],["setVisible","ExcelConnection","ExcelConnection.html#method-i-setVisible","(v)",""],["set_border_color","Worksheet","Worksheet.html#method-i-set_border_color","(range, color)","<p>sets border color of cells in range\n<p>range &mdash; range to be colorized\n<p>color &mdash; color to be used, must be an ExcelColor …\n"],["set_content","Worksheet","Worksheet.html#method-i-set_content","(range, content)","<p>sets content in a range\n<p>range &mdash; range in worksheet, e.g. &#39;A1:B3&#39;\n<p>content &mdash; may be a matrix, a vector …\n"],["set_fill_color","Worksheet","Worksheet.html#method-i-set_fill_color","(range, color)","<p>fills cells in range with color\n<p>range &mdash; range to be colorized\n<p>color &mdash; color to be used, must be an ExcelColor …\n"],["set_font_color","Worksheet","Worksheet.html#method-i-set_font_color","(range, color)","<p>sets font color of cells in range\n<p>range &mdash; range to be colorized\n<p>color &mdash; color to be used, must be an ExcelColor …\n"],["uninitialize_com","ExcelConnection","ExcelConnection.html#method-c-uninitialize_com","()","<p>uninitializes com manually, not recommended! should happen automatically\nwhen <code>ExcelConnection#quit</code> is …\n"],["version","ExcelConnection","ExcelConnection.html#method-i-version","()","<p>gets excel version\n"],["visible=","ExcelConnection","ExcelConnection.html#method-i-visible-3D","(v)","<p>whether the excel instance should be visible or not\n"],["workbook","ExcelConnection","ExcelConnection.html#method-i-workbook","(file)","<p>opens a workbook. Optional block possible where workbook gets closed on\nblocks end, e.g. <code>con.workbook{|wb|</code> …\n"],["worksheet","Workbook","Workbook.html#method-i-worksheet","(name)","<p>gets a worksheet\n<p>name &mdash; name of worksheet to get\n\n"],["LICENSE","","LICENSE.html","","\n<pre> Apache License\n Version 2.0, January 2004\nhttp://www.apache.org/licenses/</pre>\n<p>TERMS AND CONDITIONS …\n"],["jruby_excelcom.gemspec","","jruby_excelcom_gemspec.html","","<p>Gem::Specification.new do |s|\n\n<pre>s.name = &#39;jruby_excelcom&#39;\ns.version = &#39;0.0.1&#39;\ns.date ...</pre>\n"]]}}
Binary file
@@ -0,0 +1,228 @@
1
+ Searcher = function(data) {
2
+ this.data = data;
3
+ this.handlers = [];
4
+ }
5
+
6
+ Searcher.prototype = new function() {
7
+ // search is performed in chunks of 1000 for non-blocking user input
8
+ var CHUNK_SIZE = 1000;
9
+ // do not try to find more than 100 results
10
+ var MAX_RESULTS = 100;
11
+ var huid = 1;
12
+ var suid = 1;
13
+ var runs = 0;
14
+
15
+ this.find = function(query) {
16
+ var queries = splitQuery(query);
17
+ var regexps = buildRegexps(queries);
18
+ var highlighters = buildHilighters(queries);
19
+ var state = { from: 0, pass: 0, limit: MAX_RESULTS, n: suid++};
20
+ var _this = this;
21
+
22
+ this.currentSuid = state.n;
23
+
24
+ if (!query) return;
25
+
26
+ var run = function() {
27
+ // stop current search thread if new search started
28
+ if (state.n != _this.currentSuid) return;
29
+
30
+ var results =
31
+ performSearch(_this.data, regexps, queries, highlighters, state);
32
+ var hasMore = (state.limit > 0 && state.pass < 4);
33
+
34
+ triggerResults.call(_this, results, !hasMore);
35
+ if (hasMore) {
36
+ setTimeout(run, 2);
37
+ }
38
+ runs++;
39
+ };
40
+ runs = 0;
41
+
42
+ // start search thread
43
+ run();
44
+ }
45
+
46
+ /* ----- Events ------ */
47
+ this.ready = function(fn) {
48
+ fn.huid = huid;
49
+ this.handlers.push(fn);
50
+ }
51
+
52
+ /* ----- Utilities ------ */
53
+ function splitQuery(query) {
54
+ return jQuery.grep(query.split(/(\s+|::?|\(\)?)/), function(string) {
55
+ return string.match(/\S/);
56
+ });
57
+ }
58
+
59
+ function buildRegexps(queries) {
60
+ return jQuery.map(queries, function(query) {
61
+ return new RegExp(query.replace(/(.)/g, '([$1])([^$1]*?)'), 'i');
62
+ });
63
+ }
64
+
65
+ function buildHilighters(queries) {
66
+ return jQuery.map(queries, function(query) {
67
+ return jQuery.map(query.split(''), function(l, i) {
68
+ return '\u0001$' + (i*2+1) + '\u0002$' + (i*2+2);
69
+ }).join('');
70
+ });
71
+ }
72
+
73
+ // function longMatchRegexp(index, longIndex, regexps) {
74
+ // for (var i = regexps.length - 1; i >= 0; i--){
75
+ // if (!index.match(regexps[i]) && !longIndex.match(regexps[i])) return false;
76
+ // };
77
+ // return true;
78
+ // }
79
+
80
+
81
+ /* ----- Mathchers ------ */
82
+
83
+ /*
84
+ * This record matches if the index starts with queries[0] and the record
85
+ * matches all of the regexps
86
+ */
87
+ function matchPassBeginning(index, longIndex, queries, regexps) {
88
+ if (index.indexOf(queries[0]) != 0) return false;
89
+ for (var i=1, l = regexps.length; i < l; i++) {
90
+ if (!index.match(regexps[i]) && !longIndex.match(regexps[i]))
91
+ return false;
92
+ };
93
+ return true;
94
+ }
95
+
96
+ /*
97
+ * This record matches if the longIndex starts with queries[0] and the
98
+ * longIndex matches all of the regexps
99
+ */
100
+ function matchPassLongIndex(index, longIndex, queries, regexps) {
101
+ if (longIndex.indexOf(queries[0]) != 0) return false;
102
+ for (var i=1, l = regexps.length; i < l; i++) {
103
+ if (!longIndex.match(regexps[i]))
104
+ return false;
105
+ };
106
+ return true;
107
+ }
108
+
109
+ /*
110
+ * This record matches if the index contains queries[0] and the record
111
+ * matches all of the regexps
112
+ */
113
+ function matchPassContains(index, longIndex, queries, regexps) {
114
+ if (index.indexOf(queries[0]) == -1) return false;
115
+ for (var i=1, l = regexps.length; i < l; i++) {
116
+ if (!index.match(regexps[i]) && !longIndex.match(regexps[i]))
117
+ return false;
118
+ };
119
+ return true;
120
+ }
121
+
122
+ /*
123
+ * This record matches if regexps[0] matches the index and the record
124
+ * matches all of the regexps
125
+ */
126
+ function matchPassRegexp(index, longIndex, queries, regexps) {
127
+ if (!index.match(regexps[0])) return false;
128
+ for (var i=1, l = regexps.length; i < l; i++) {
129
+ if (!index.match(regexps[i]) && !longIndex.match(regexps[i]))
130
+ return false;
131
+ };
132
+ return true;
133
+ }
134
+
135
+
136
+ /* ----- Highlighters ------ */
137
+ function highlightRegexp(info, queries, regexps, highlighters) {
138
+ var result = createResult(info);
139
+ for (var i=0, l = regexps.length; i < l; i++) {
140
+ result.title = result.title.replace(regexps[i], highlighters[i]);
141
+ result.namespace = result.namespace.replace(regexps[i], highlighters[i]);
142
+ };
143
+ return result;
144
+ }
145
+
146
+ function hltSubstring(string, pos, length) {
147
+ return string.substring(0, pos) + '\u0001' + string.substring(pos, pos + length) + '\u0002' + string.substring(pos + length);
148
+ }
149
+
150
+ function highlightQuery(info, queries, regexps, highlighters) {
151
+ var result = createResult(info);
152
+ var pos = 0;
153
+ var lcTitle = result.title.toLowerCase();
154
+
155
+ pos = lcTitle.indexOf(queries[0]);
156
+ if (pos != -1) {
157
+ result.title = hltSubstring(result.title, pos, queries[0].length);
158
+ }
159
+
160
+ result.namespace = result.namespace.replace(regexps[0], highlighters[0]);
161
+ for (var i=1, l = regexps.length; i < l; i++) {
162
+ result.title = result.title.replace(regexps[i], highlighters[i]);
163
+ result.namespace = result.namespace.replace(regexps[i], highlighters[i]);
164
+ };
165
+ return result;
166
+ }
167
+
168
+ function createResult(info) {
169
+ var result = {};
170
+ result.title = info[0];
171
+ result.namespace = info[1];
172
+ result.path = info[2];
173
+ result.params = info[3];
174
+ result.snippet = info[4];
175
+ return result;
176
+ }
177
+
178
+ /* ----- Searching ------ */
179
+ function performSearch(data, regexps, queries, highlighters, state) {
180
+ var searchIndex = data.searchIndex;
181
+ var longSearchIndex = data.longSearchIndex;
182
+ var info = data.info;
183
+ var result = [];
184
+ var i = state.from;
185
+ var l = searchIndex.length;
186
+ var togo = CHUNK_SIZE;
187
+ var matchFunc, hltFunc;
188
+
189
+ while (state.pass < 4 && state.limit > 0 && togo > 0) {
190
+ if (state.pass == 0) {
191
+ matchFunc = matchPassBeginning;
192
+ hltFunc = highlightQuery;
193
+ } else if (state.pass == 1) {
194
+ matchFunc = matchPassLongIndex;
195
+ hltFunc = highlightQuery;
196
+ } else if (state.pass == 2) {
197
+ matchFunc = matchPassContains;
198
+ hltFunc = highlightQuery;
199
+ } else if (state.pass == 3) {
200
+ matchFunc = matchPassRegexp;
201
+ hltFunc = highlightRegexp;
202
+ }
203
+
204
+ for (; togo > 0 && i < l && state.limit > 0; i++, togo--) {
205
+ if (info[i].n == state.n) continue;
206
+ if (matchFunc(searchIndex[i], longSearchIndex[i], queries, regexps)) {
207
+ info[i].n = state.n;
208
+ result.push(hltFunc(info[i], queries, regexps, highlighters));
209
+ state.limit--;
210
+ }
211
+ };
212
+ if (searchIndex.length <= i) {
213
+ state.pass++;
214
+ i = state.from = 0;
215
+ } else {
216
+ state.from = i;
217
+ }
218
+ }
219
+ return result;
220
+ }
221
+
222
+ function triggerResults(results, isLast) {
223
+ jQuery.each(this.handlers, function(i, fn) {
224
+ fn.call(this, results, isLast)
225
+ })
226
+ }
227
+ }
228
+
Binary file