jruby_excelcom 0.0.1-java
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.//jruby_excelcom.gemspec +13 -0
- data/LICENSE +201 -0
- data/doc/ExcelColor.html +95 -0
- data/doc/ExcelConnection.html +709 -0
- data/doc/JavaExcelcom.html +95 -0
- data/doc/LICENSE.html +283 -0
- data/doc/MiniTest.html +95 -0
- data/doc/Object.html +153 -0
- data/doc/Time.html +95 -0
- data/doc/Workbook.html +520 -0
- data/doc/Worksheet.html +1111 -0
- data/doc/created.rid +12 -0
- data/doc/css/fonts.css +167 -0
- data/doc/css/rdoc.css +590 -0
- data/doc/fonts/Lato-Light.ttf +0 -0
- data/doc/fonts/Lato-LightItalic.ttf +0 -0
- data/doc/fonts/Lato-Regular.ttf +0 -0
- data/doc/fonts/Lato-RegularItalic.ttf +0 -0
- data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
- data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
- data/doc/images/add.png +0 -0
- data/doc/images/arrow_up.png +0 -0
- data/doc/images/brick.png +0 -0
- data/doc/images/brick_link.png +0 -0
- data/doc/images/bug.png +0 -0
- data/doc/images/bullet_black.png +0 -0
- data/doc/images/bullet_toggle_minus.png +0 -0
- data/doc/images/bullet_toggle_plus.png +0 -0
- data/doc/images/date.png +0 -0
- data/doc/images/delete.png +0 -0
- data/doc/images/find.png +0 -0
- data/doc/images/loadingAnimation.gif +0 -0
- data/doc/images/macFFBgHack.png +0 -0
- data/doc/images/package.png +0 -0
- data/doc/images/page_green.png +0 -0
- data/doc/images/page_white_text.png +0 -0
- data/doc/images/page_white_width.png +0 -0
- data/doc/images/plugin.png +0 -0
- data/doc/images/ruby.png +0 -0
- data/doc/images/tag_blue.png +0 -0
- data/doc/images/tag_green.png +0 -0
- data/doc/images/transparent.png +0 -0
- data/doc/images/wrench.png +0 -0
- data/doc/images/wrench_orange.png +0 -0
- data/doc/images/zoom.png +0 -0
- data/doc/index.html +103 -0
- data/doc/jruby_excelcom_gemspec.html +98 -0
- data/doc/js/darkfish.js +161 -0
- data/doc/js/jquery.js +4 -0
- data/doc/js/navigation.js +142 -0
- data/doc/js/navigation.js.gz +0 -0
- data/doc/js/search.js +109 -0
- data/doc/js/search_index.js +1 -0
- data/doc/js/search_index.js.gz +0 -0
- data/doc/js/searcher.js +228 -0
- data/doc/js/searcher.js.gz +0 -0
- data/doc/table_of_contents.html +337 -0
- data/lib/jars/excelcom-0.0.5.jar +0 -0
- data/lib/jars/jna-4.4.0.jar +0 -0
- data/lib/jars/jna-platform-4.4.0.jar +0 -0
- data/lib/jruby_excelcom/excel_connection.rb +81 -0
- data/lib/jruby_excelcom/workbook.rb +46 -0
- data/lib/jruby_excelcom/worksheet.rb +136 -0
- data/lib/jruby_excelcom.rb +22 -0
- data/test/resources/test.xlsx +0 -0
- data/test/resources/test2.xlsx +0 -0
- data/test/test_helper.rb +4 -0
- data/test/unit/excel_connection_spec.rb +38 -0
- data/test/unit/workbook_spec.rb +41 -0
- data/test/unit/worksheet_spec.rb +100 -0
- 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 — 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 — 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 — 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>'s dimensions …\n"],["content=","Worksheet","Worksheet.html#method-i-content-3D","(hash)","<p>sets content in a range\n<p>hash — must contain <code>:range</code> and <code>:content</code>, e.g.\n<code>{:range => 'A1:A3', :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 — 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 — 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 — 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 — range to be colorized\n<p>color — 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 — range in worksheet, e.g. 'A1:B3'\n<p>content — 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 — range to be colorized\n<p>color — 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 — range to be colorized\n<p>color — 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 — 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          = 'jruby_excelcom'\ns.version       = '0.0.1'\ns.date     ...</pre>\n"]]}}
         | 
| Binary file | 
    
        data/doc/js/searcher.js
    ADDED
    
    | @@ -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 |