roma-client 0.4.3 → 0.4.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (85) hide show
  1. checksums.yaml +4 -4
  2. data/{CHANGELOG → CHANGELOG.md} +8 -5
  3. data/Gemfile.lock +23 -15
  4. data/README.md +62 -0
  5. data/Rakefile +3 -3
  6. data/doc/CHANGELOG_md.html +119 -0
  7. data/doc/README_md.html +161 -0
  8. data/doc/Roma/Client/ClientPool.html +716 -0
  9. data/doc/Roma/Client/ClientRoutingTable.html +495 -0
  10. data/doc/Roma/Client/ConPool.html +484 -0
  11. data/doc/Roma/Client/Plugin/Alist.html +1276 -0
  12. data/doc/Roma/Client/Plugin/Map.html +531 -0
  13. data/doc/Roma/Client/Plugin/MapCount.html +401 -0
  14. data/doc/Roma/Client/Plugin.html +95 -0
  15. data/doc/Roma/Client/Proxy/ClientHandler.html +273 -0
  16. data/doc/Roma/Client/Proxy/Conpool.html +394 -0
  17. data/doc/Roma/Client/Proxy/Daemon.html +305 -0
  18. data/doc/Roma/Client/Proxy/RomaHandler.html +217 -0
  19. data/doc/Roma/Client/Proxy.html +95 -0
  20. data/doc/Roma/Client/RomaClient.html +1339 -0
  21. data/doc/Roma/Client/Sender.html +482 -0
  22. data/doc/Roma/Client/Stats.html +162 -0
  23. data/doc/Roma/Client/VERSION.html +141 -0
  24. data/doc/Roma/Client.html +95 -0
  25. data/doc/Roma/Logging/RLogger/ExtLogDev.html +159 -0
  26. data/doc/Roma/Logging/RLogger/ExtShiftAge.html +95 -0
  27. data/doc/Roma/Logging/RLogger/ExtTrace.html +109 -0
  28. data/doc/Roma/Logging/RLogger/Severity.html +139 -0
  29. data/doc/Roma/Logging/RLogger.html +786 -0
  30. data/doc/Roma/Logging.html +95 -0
  31. data/doc/Roma/Routing/RoutingData/RandomNodeListMaker.html +311 -0
  32. data/doc/Roma/Routing/RoutingData.html +912 -0
  33. data/doc/Roma/Routing.html +95 -0
  34. data/doc/Roma.html +95 -0
  35. data/doc/created.rid +20 -0
  36. data/doc/css/fonts.css +167 -0
  37. data/doc/css/rdoc.css +590 -0
  38. data/doc/fonts/Lato-Light.ttf +0 -0
  39. data/doc/fonts/Lato-LightItalic.ttf +0 -0
  40. data/doc/fonts/Lato-Regular.ttf +0 -0
  41. data/doc/fonts/Lato-RegularItalic.ttf +0 -0
  42. data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
  43. data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
  44. data/doc/images/add.png +0 -0
  45. data/doc/images/arrow_up.png +0 -0
  46. data/doc/images/brick.png +0 -0
  47. data/doc/images/brick_link.png +0 -0
  48. data/doc/images/bug.png +0 -0
  49. data/doc/images/bullet_black.png +0 -0
  50. data/doc/images/bullet_toggle_minus.png +0 -0
  51. data/doc/images/bullet_toggle_plus.png +0 -0
  52. data/doc/images/date.png +0 -0
  53. data/doc/images/delete.png +0 -0
  54. data/doc/images/find.png +0 -0
  55. data/doc/images/loadingAnimation.gif +0 -0
  56. data/doc/images/macFFBgHack.png +0 -0
  57. data/doc/images/package.png +0 -0
  58. data/doc/images/page_green.png +0 -0
  59. data/doc/images/page_white_text.png +0 -0
  60. data/doc/images/page_white_width.png +0 -0
  61. data/doc/images/plugin.png +0 -0
  62. data/doc/images/ruby.png +0 -0
  63. data/doc/images/tag_blue.png +0 -0
  64. data/doc/images/tag_green.png +0 -0
  65. data/doc/images/transparent.png +0 -0
  66. data/doc/images/wrench.png +0 -0
  67. data/doc/images/wrench_orange.png +0 -0
  68. data/doc/images/zoom.png +0 -0
  69. data/doc/index.html +210 -0
  70. data/doc/js/darkfish.js +161 -0
  71. data/doc/js/jquery.js +4 -0
  72. data/doc/js/navigation.js +142 -0
  73. data/doc/js/navigation.js.gz +0 -0
  74. data/doc/js/search.js +109 -0
  75. data/doc/js/search_index.js +1 -0
  76. data/doc/js/search_index.js.gz +0 -0
  77. data/doc/js/searcher.js +228 -0
  78. data/doc/js/searcher.js.gz +0 -0
  79. data/doc/table_of_contents.html +972 -0
  80. data/lib/roma/client/rclient.rb +2 -1
  81. data/lib/roma/client/sender.rb +2 -2
  82. data/lib/roma/client/version.rb +1 -1
  83. data/lib/roma/client.rb +0 -21
  84. metadata +84 -10
  85. data/README +0 -17
@@ -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":["roma","client","clientpool","clientroutingtable","conpool","plugin","alist","map","mapcount","proxy","clienthandler","conpool","daemon","romahandler","romaclient","sender","stats","version","logging","rlogger","extlogdev","extshiftage","exttrace","severity","routing","routingdata","randomnodelistmaker","[]()","[]=()","add()","add_plugin_module()","alist_at()","alist_clear()","alist_delete()","alist_delete_at()","alist_empty?()","alist_expired_swap_and_insert()","alist_expired_swap_and_push()","alist_expired_swap_and_sized_insert()","alist_expired_swap_and_sized_push()","alist_first()","alist_gets()","alist_gets_with_time()","alist_include?()","alist_index()","alist_insert()","alist_join()","alist_join_with_time()","alist_last()","alist_length()","alist_pop()","alist_push()","alist_shift()","alist_sized_insert()","alist_sized_push()","alist_swap_and_insert()","alist_swap_and_push()","alist_swap_and_sized_insert()","alist_swap_and_sized_push()","alist_to_json()","alist_to_s()","alist_update_at()","append()","cas()","client()","client_pools()","clients()","close()","close_all()","close_all()","close_at()","close_at()","close_same_host()","create()","create_connection()","create_connection()","create_nodes_from_v_idx()","create_singleton_instance()","debug()","debug?()","decr()","delete()","delete_connection()","each_log_all()","each_log_one()","error()","error?()","extendlogdev()","fatal()","fatal?()","flush_all()","get()","get_connection()","get_connection()","get_file_list()","get_histgram()","get_lost_vnodes()","get_other_one()","get_other_one_repethost()","get_roma_handler()","get_vnode_id()","gets()","incr()","info()","info?()","initialize_logger()","instance()","instance()","level=()","list()","load()","load_log_all()","load_log_one()","load_snapshot()","make_rttable()","map_clear()","map_delete()","map_empty?()","map_get()","map_key?()","map_keys()","map_set()","map_size()","map_to_s()","map_value?()","map_values()","mapcount_countup()","mapcount_countup_ms()","mapcount_get()","mapcount_get_ms()","mapcount_update()","mapcount_update_ms()","max_pool_size()","max_pool_size=()","new()","new()","new()","new()","new()","new()","new()","new()","new()","new()","new()","next_vnode()","nodes()","out()","parse_log()","plugin_modules()","plugin_modules=()","pool_count()","post_init()","post_init()","prepend()","proc_failed()","push_client()","receive_data()","release()","release_all()","replace()","return_connection()","return_connection()","rttable()","rttable_last_update()","save()","search_mask()","search_node()","search_nodes()","send_command()","send_route_mklhash_command()","send_routedump_command()","send_routedump_yaml_command()","send_stats_command()","send_verbosity_command()","send_version_command()","set()","snapshot()","start()","stats()","trace()","trace?()","unbind()","unbind()","unknown()","update_rttable()","verbosity()","version()","vnodes()","warn()","warn?()","changelog","readme"],"longSearchIndex":["roma","roma::client","roma::client::clientpool","roma::client::clientroutingtable","roma::client::conpool","roma::client::plugin","roma::client::plugin::alist","roma::client::plugin::map","roma::client::plugin::mapcount","roma::client::proxy","roma::client::proxy::clienthandler","roma::client::proxy::conpool","roma::client::proxy::daemon","roma::client::proxy::romahandler","roma::client::romaclient","roma::client::sender","roma::client::stats","roma::client::version","roma::logging","roma::logging::rlogger","roma::logging::rlogger::extlogdev","roma::logging::rlogger::extshiftage","roma::logging::rlogger::exttrace","roma::logging::rlogger::severity","roma::routing","roma::routing::routingdata","roma::routing::routingdata::randomnodelistmaker","roma::client::romaclient#[]()","roma::client::romaclient#[]=()","roma::client::romaclient#add()","roma::client::clientpool#add_plugin_module()","roma::client::plugin::alist#alist_at()","roma::client::plugin::alist#alist_clear()","roma::client::plugin::alist#alist_delete()","roma::client::plugin::alist#alist_delete_at()","roma::client::plugin::alist#alist_empty?()","roma::client::plugin::alist#alist_expired_swap_and_insert()","roma::client::plugin::alist#alist_expired_swap_and_push()","roma::client::plugin::alist#alist_expired_swap_and_sized_insert()","roma::client::plugin::alist#alist_expired_swap_and_sized_push()","roma::client::plugin::alist#alist_first()","roma::client::plugin::alist#alist_gets()","roma::client::plugin::alist#alist_gets_with_time()","roma::client::plugin::alist#alist_include?()","roma::client::plugin::alist#alist_index()","roma::client::plugin::alist#alist_insert()","roma::client::plugin::alist#alist_join()","roma::client::plugin::alist#alist_join_with_time()","roma::client::plugin::alist#alist_last()","roma::client::plugin::alist#alist_length()","roma::client::plugin::alist#alist_pop()","roma::client::plugin::alist#alist_push()","roma::client::plugin::alist#alist_shift()","roma::client::plugin::alist#alist_sized_insert()","roma::client::plugin::alist#alist_sized_push()","roma::client::plugin::alist#alist_swap_and_insert()","roma::client::plugin::alist#alist_swap_and_push()","roma::client::plugin::alist#alist_swap_and_sized_insert()","roma::client::plugin::alist#alist_swap_and_sized_push()","roma::client::plugin::alist#alist_to_json()","roma::client::plugin::alist#alist_to_s()","roma::client::plugin::alist#alist_update_at()","roma::client::romaclient#append()","roma::client::romaclient#cas()","roma::client::clientpool#client()","roma::client::clientpool::client_pools()","roma::client::clientpool#clients()","roma::logging::rlogger#close()","roma::client::conpool#close_all()","roma::client::proxy::conpool#close_all()","roma::client::conpool#close_at()","roma::client::proxy::conpool#close_at()","roma::client::conpool#close_same_host()","roma::routing::routingdata::create()","roma::client::conpool#create_connection()","roma::client::proxy::conpool#create_connection()","roma::routing::routingdata#create_nodes_from_v_idx()","roma::logging::rlogger::create_singleton_instance()","roma::logging::rlogger#debug()","roma::logging::rlogger#debug?()","roma::client::romaclient#decr()","roma::client::romaclient#delete()","roma::client::conpool#delete_connection()","roma::routing::routingdata#each_log_all()","roma::routing::routingdata#each_log_one()","roma::logging::rlogger#error()","roma::logging::rlogger#error?()","roma::logging::rlogger::extlogdev#extendlogdev()","roma::logging::rlogger#fatal()","roma::logging::rlogger#fatal?()","roma::client::romaclient#flush_all()","roma::client::romaclient#get()","roma::client::conpool#get_connection()","roma::client::proxy::conpool#get_connection()","roma::routing::routingdata#get_file_list()","roma::routing::routingdata#get_histgram()","roma::routing::routingdata#get_lost_vnodes()","roma::routing::routingdata::randomnodelistmaker#get_other_one()","roma::routing::routingdata::randomnodelistmaker#get_other_one_repethost()","roma::client::proxy::clienthandler#get_roma_handler()","roma::client::clientroutingtable#get_vnode_id()","roma::client::romaclient#gets()","roma::client::romaclient#incr()","roma::logging::rlogger#info()","roma::logging::rlogger#info?()","roma::client::proxy::daemon#initialize_logger()","roma::client::clientpool::instance()","roma::logging::rlogger::instance()","roma::logging::rlogger#level=()","roma::routing::routingdata::randomnodelistmaker#list()","roma::routing::routingdata::load()","roma::routing::routingdata#load_log_all()","roma::routing::routingdata#load_log_one()","roma::routing::routingdata::load_snapshot()","roma::client::romaclient#make_rttable()","roma::client::plugin::map#map_clear()","roma::client::plugin::map#map_delete()","roma::client::plugin::map#map_empty?()","roma::client::plugin::map#map_get()","roma::client::plugin::map#map_key?()","roma::client::plugin::map#map_keys()","roma::client::plugin::map#map_set()","roma::client::plugin::map#map_size()","roma::client::plugin::map#map_to_s()","roma::client::plugin::map#map_value?()","roma::client::plugin::map#map_values()","roma::client::plugin::mapcount#mapcount_countup()","roma::client::plugin::mapcount#mapcount_countup_ms()","roma::client::plugin::mapcount#mapcount_get()","roma::client::plugin::mapcount#mapcount_get_ms()","roma::client::plugin::mapcount#mapcount_update()","roma::client::plugin::mapcount#mapcount_update_ms()","roma::client::clientpool#max_pool_size()","roma::client::clientpool#max_pool_size=()","roma::client::clientpool::new()","roma::client::clientroutingtable::new()","roma::client::conpool::new()","roma::client::proxy::conpool::new()","roma::client::proxy::daemon::new()","roma::client::romaclient::new()","roma::client::sender::new()","roma::client::stats::new()","roma::logging::rlogger::new()","roma::routing::routingdata::new()","roma::routing::routingdata::randomnodelistmaker::new()","roma::routing::routingdata#next_vnode()","roma::client::clientroutingtable#nodes()","roma::client::romaclient#out()","roma::routing::routingdata#parse_log()","roma::client::clientpool#plugin_modules()","roma::client::clientpool#plugin_modules=()","roma::client::clientpool#pool_count()","roma::client::proxy::clienthandler#post_init()","roma::client::proxy::romahandler#post_init()","roma::client::romaclient#prepend()","roma::client::clientroutingtable#proc_failed()","roma::client::clientpool#push_client()","roma::client::proxy::clienthandler#receive_data()","roma::client::clientpool#release()","roma::client::clientpool::release_all()","roma::client::romaclient#replace()","roma::client::conpool#return_connection()","roma::client::proxy::conpool#return_connection()","roma::client::proxy::daemon::rttable()","roma::client::romaclient#rttable_last_update()","roma::routing::routingdata#save()","roma::routing::routingdata#search_mask()","roma::client::clientroutingtable#search_node()","roma::client::clientroutingtable#search_nodes()","roma::client::sender#send_command()","roma::client::sender#send_route_mklhash_command()","roma::client::sender#send_routedump_command()","roma::client::sender#send_routedump_yaml_command()","roma::client::sender#send_stats_command()","roma::client::sender#send_verbosity_command()","roma::client::sender#send_version_command()","roma::client::romaclient#set()","roma::routing::routingdata::snapshot()","roma::client::proxy::daemon#start()","roma::client::romaclient#stats()","roma::logging::rlogger#trace()","roma::logging::rlogger#trace?()","roma::client::proxy::clienthandler#unbind()","roma::client::proxy::romahandler#unbind()","roma::logging::rlogger#unknown()","roma::client::romaclient#update_rttable()","roma::client::romaclient#verbosity()","roma::client::romaclient#version()","roma::client::clientroutingtable#vnodes()","roma::logging::rlogger#warn()","roma::logging::rlogger#warn?()","",""],"info":[["Roma","","Roma.html","",""],["Roma::Client","","Roma/Client.html","",""],["Roma::Client::ClientPool","","Roma/Client/ClientPool.html","","<p>RomaClient Pool class\n<p>This class is implemented as Singleton. You can get RomaClient as follows.\n\n<pre>client ...</pre>\n"],["Roma::Client::ClientRoutingTable","","Roma/Client/ClientRoutingTable.html","",""],["Roma::Client::ConPool","","Roma/Client/ConPool.html","",""],["Roma::Client::Plugin","","Roma/Client/Plugin.html","",""],["Roma::Client::Plugin::Alist","","Roma/Client/Plugin/Alist.html","",""],["Roma::Client::Plugin::Map","","Roma/Client/Plugin/Map.html","",""],["Roma::Client::Plugin::MapCount","","Roma/Client/Plugin/MapCount.html","","<p>MapCount plugin module for ROMA client\n"],["Roma::Client::Proxy","","Roma/Client/Proxy.html","",""],["Roma::Client::Proxy::ClientHandler","","Roma/Client/Proxy/ClientHandler.html","",""],["Roma::Client::Proxy::Conpool","","Roma/Client/Proxy/Conpool.html","",""],["Roma::Client::Proxy::Daemon","","Roma/Client/Proxy/Daemon.html","",""],["Roma::Client::Proxy::RomaHandler","","Roma/Client/Proxy/RomaHandler.html","",""],["Roma::Client::RomaClient","","Roma/Client/RomaClient.html","","<p>Class to access ROMA .\n"],["Roma::Client::Sender","","Roma/Client/Sender.html","",""],["Roma::Client::Stats","","Roma/Client/Stats.html","","<p>TODO: Implement accessors and return values with correct type Now:\nclient.stats #=&gt; “2” …\n"],["Roma::Client::VERSION","","Roma/Client/VERSION.html","","<p>What Is This Library?\n<p>ROMA client proxy daemon&#39;s version module\n<p>What Is This Library?\n"],["Roma::Logging","","Roma/Logging.html","",""],["Roma::Logging::RLogger","","Roma/Logging/RLogger.html","",""],["Roma::Logging::RLogger::ExtLogDev","","Roma/Logging/RLogger/ExtLogDev.html","",""],["Roma::Logging::RLogger::ExtShiftAge","","Roma/Logging/RLogger/ExtShiftAge.html","",""],["Roma::Logging::RLogger::ExtTrace","","Roma/Logging/RLogger/ExtTrace.html","",""],["Roma::Logging::RLogger::Severity","","Roma/Logging/RLogger/Severity.html","",""],["Roma::Routing","","Roma/Routing.html","",""],["Roma::Routing::RoutingData","","Roma/Routing/RoutingData.html","",""],["Roma::Routing::RoutingData::RandomNodeListMaker","","Roma/Routing/RoutingData/RandomNodeListMaker.html","",""],["[]","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-5B-5D","(key)","<p>Get value from ROMA .\n<p>key &mdash; key for roma.\n\n<p><code>returen</code>\n"],["[]=","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-5B-5D-3D","(key, value)","<p>Set value to ROMA . please see set method .\n"],["add","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-add","(key, val, expt = 0, raw = false)","<p>Add value to ROMA .\n<p>If same key exists in ROMA, this method don&#39;t overwrite value and\nreturn NOT_STORED …\n"],["add_plugin_module","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-add_plugin_module","(m)","<p>add plugin module\n"],["alist_at","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_at","(key, index)",""],["alist_clear","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_clear","(key)",""],["alist_delete","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_delete","(key, value)",""],["alist_delete_at","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_delete_at","(key, index)",""],["alist_empty?","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_empty-3F","(key)",""],["alist_expired_swap_and_insert","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_expired_swap_and_insert","(key, expt, value)",""],["alist_expired_swap_and_push","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_expired_swap_and_push","(key, expt, value)",""],["alist_expired_swap_and_sized_insert","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_expired_swap_and_sized_insert","(key, expt, array_size, value)",""],["alist_expired_swap_and_sized_push","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_expired_swap_and_sized_push","(key, expt, array_size, value)",""],["alist_first","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_first","(key)",""],["alist_gets","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_gets","(key, range=nil)",""],["alist_gets_with_time","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_gets_with_time","(key, range=nil)",""],["alist_include?","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_include-3F","(key, value)",""],["alist_index","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_index","(key, value)",""],["alist_insert","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_insert","(key, index, value)",""],["alist_join","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_join","(key, sep, range=nil)",""],["alist_join_with_time","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_join_with_time","(key, sep, range=nil)",""],["alist_last","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_last","(key)",""],["alist_length","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_length","(key)",""],["alist_pop","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_pop","(key)",""],["alist_push","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_push","(key, value)",""],["alist_shift","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_shift","(key)",""],["alist_sized_insert","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_sized_insert","(key, array_size, value)",""],["alist_sized_push","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_sized_push","(key, array_size, value)",""],["alist_swap_and_insert","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_swap_and_insert","(key, value)",""],["alist_swap_and_push","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_swap_and_push","(key, value)",""],["alist_swap_and_sized_insert","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_swap_and_sized_insert","(key, array_size, value)",""],["alist_swap_and_sized_push","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_swap_and_sized_push","(key, array_size, value)",""],["alist_to_json","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_to_json","(key, range=nil)",""],["alist_to_s","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_to_s","(key, range=nil)",""],["alist_update_at","Roma::Client::Plugin::Alist","Roma/Client/Plugin/Alist.html#method-i-alist_update_at","(key, index, value)",""],["append","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-append","(key, val, expt = 0)","<p>Append value to exists string .\n<p>If same key exists in ROMA, this method append value . If same key\ndoesn&#39;t …\n"],["cas","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-cas","(key, expt = 0, raw = false)","<p>Compare And Swap value .\n<p>key &mdash; key for cas .\n<p>value &mdash; store value .\n"],["client","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-client","()","<p>get RomaClient instance\n<p>type &mdash; RomaClient instance group.\n<p>return &mdash; RomaClient instance\n"],["client_pools","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-c-client_pools","()","<p>get all pool\n"],["clients","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-clients","()","<p>get all clients\n"],["close","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-close","()",""],["close_all","Roma::Client::ConPool","Roma/Client/ConPool.html#method-i-close_all","()",""],["close_all","Roma::Client::Proxy::Conpool","Roma/Client/Proxy/Conpool.html#method-i-close_all","()",""],["close_at","Roma::Client::ConPool","Roma/Client/ConPool.html#method-i-close_at","(ap)",""],["close_at","Roma::Client::Proxy::Conpool","Roma/Client/Proxy/Conpool.html#method-i-close_at","(ap)",""],["close_same_host","Roma::Client::ConPool","Roma/Client/ConPool.html#method-i-close_same_host","(ap)",""],["create","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-c-create","(dgst_bits,div_bits,rn,nodes,repethost=false)",""],["create_connection","Roma::Client::ConPool","Roma/Client/ConPool.html#method-i-create_connection","(ap)",""],["create_connection","Roma::Client::Proxy::Conpool","Roma/Client/Proxy/Conpool.html#method-i-create_connection","(ap, handler)",""],["create_nodes_from_v_idx","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-create_nodes_from_v_idx","()",""],["create_singleton_instance","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-c-create_singleton_instance","(logdev, shift_age = 0, shift_size = 1048576)",""],["debug","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-debug","(progname = nil, &block)",""],["debug?","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-debug-3F","()",""],["decr","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-decr","(key, val = 1)","<p>decrement value .\n<p>key &mdash; key for decremental .\n<p>val &mdash; decremental value .\n"],["delete","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-delete","(key)","<p>Delete value .\n<p>key &mdash; key for delete .\n<p>return &mdash; return follow set status .\n"],["delete_connection","Roma::Client::ConPool","Roma/Client/ConPool.html#method-i-delete_connection","(ap)",""],["each_log_all","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-each_log_all","(fname)",""],["each_log_one","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-each_log_one","(fname)",""],["error","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-error","(progname = nil, &block)",""],["error?","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-error-3F","()",""],["extendLogDev","Roma::Logging::RLogger::ExtLogDev","Roma/Logging/RLogger/ExtLogDev.html#method-i-extendLogDev","()",""],["fatal","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-fatal","(progname = nil, &block)",""],["fatal?","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-fatal-3F","()",""],["flush_all","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-flush_all","()",""],["get","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-get","(key, raw = false)","<p>get value\n<p>key &mdash; key for get .\n<p>raw &mdash; If you set this value true, value isn&#39;t Marshal.load value .\n"],["get_connection","Roma::Client::ConPool","Roma/Client/ConPool.html#method-i-get_connection","(ap)",""],["get_connection","Roma::Client::Proxy::Conpool","Roma/Client/Proxy/Conpool.html#method-i-get_connection","(ap, handler)",""],["get_file_list","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-get_file_list","(fname)","<p>Returns the log file list by old ordered.\n<p>fname &mdash; Prefix of a log file.(ex.roma0_3300.route)\n\n<p>One of the following …\n"],["get_histgram","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-get_histgram","()",""],["get_lost_vnodes","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-get_lost_vnodes","()","<p>Returns the losted vnode-id list.\n"],["get_other_one","Roma::Routing::RoutingData::RandomNodeListMaker","Roma/Routing/RoutingData/RandomNodeListMaker.html#method-i-get_other_one","(exp_hosts,exp_nodes)","<p>exp_hosts &mdash; exceptional hosts(ex.)\n<p>exp_nodes &mdash; ignore\n\n"],["get_other_one_repethost","Roma::Routing::RoutingData::RandomNodeListMaker","Roma/Routing/RoutingData/RandomNodeListMaker.html#method-i-get_other_one_repethost","(exp_hosts,exp_nodes)","<p>exp_hosts &mdash; ignore\n<p>exp_nodes &mdash; exceptional nodes(ex.)\n\n"],["get_roma_handler","Roma::Client::Proxy::ClientHandler","Roma/Client/Proxy/ClientHandler.html#method-i-get_roma_handler","(cmd_line)",""],["get_vnode_id","Roma::Client::ClientRoutingTable","Roma/Client/ClientRoutingTable.html#method-i-get_vnode_id","(d)","<p>Returns a vnode-id from digest.\n"],["gets","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-gets","(keys, raw = false)","<p>get values .\n<p>keys &mdash; key array for get .\n<p>raw &mdash; If you set this value true, value isn&#39;t Marshal.load value …\n"],["incr","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-incr","(key, val = 1)","<p>increment value .\n<p>key &mdash; key for incremental .\n<p>val &mdash; incremental value .\n"],["info","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-info","(progname = nil, &block)",""],["info?","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-info-3F","()",""],["initialize_logger","Roma::Client::Proxy::Daemon","Roma/Client/Proxy/Daemon.html#method-i-initialize_logger","()",""],["instance","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-c-instance","(type = :default)","<p>get ClientPool instance\n<p>type &mdash; identifier for client groups.\n\n"],["instance","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-c-instance","()",""],["level=","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-level-3D","(severity)",""],["list","Roma::Routing::RoutingData::RandomNodeListMaker","Roma/Routing/RoutingData/RandomNodeListMaker.html#method-i-list","(n)","<p>Returns the random node-list without repetition.\n<p>n &mdash; list length\n\n"],["load","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-c-load","(fname)",""],["load_log_all","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-load_log_all","(fname)",""],["load_log_one","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-load_log_one","(fname)",""],["load_snapshot","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-c-load_snapshot","(fname)",""],["make_rttable","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-make_rttable","(node)",""],["map_clear","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_clear","(key)",""],["map_delete","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_delete","(key, mapkey)",""],["map_empty?","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_empty-3F","(key)",""],["map_get","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_get","(key, mapkey)",""],["map_key?","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_key-3F","(key, mapkey)",""],["map_keys","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_keys","(key)",""],["map_set","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_set","(key, mapkey, value, expt = 0)",""],["map_size","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_size","(key)",""],["map_to_s","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_to_s","(key)",""],["map_value?","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_value-3F","(key, value)",""],["map_values","Roma::Client::Plugin::Map","Roma/Client/Plugin/Map.html#method-i-map_values","(key)",""],["mapcount_countup","Roma::Client::Plugin::MapCount","Roma/Client/Plugin/MapCount.html#method-i-mapcount_countup","(key, sub_keys, expt = 0)","<p>countup (for JSON value)\n<p>key &mdash; key to count up data\n<p>sub_keys &mdash; sub keys to count up. You can set String &#39;sk&#39;, …\n"],["mapcount_countup_ms","Roma::Client::Plugin::MapCount","Roma/Client/Plugin/MapCount.html#method-i-mapcount_countup_ms","(key, sub_keys, expt = 0)","<p>countup (for Marshal value)\n<p>key &mdash; key to count up data\n<p>sub_keys &mdash; sub keys to count up. You can set String …\n"],["mapcount_get","Roma::Client::Plugin::MapCount","Roma/Client/Plugin/MapCount.html#method-i-mapcount_get","(key, sub_keys = nil)","<p>get mapcount (for JSON value)\n<p>key &mdash; key to get mapcount data\n<p>sub_keys &mdash; array to get mapcount data subkeys. …\n"],["mapcount_get_ms","Roma::Client::Plugin::MapCount","Roma/Client/Plugin/MapCount.html#method-i-mapcount_get_ms","(key, sub_keys = nil)","<p>get mapcount (for Marshal value)\n<p>key &mdash; key to get mapcount data\n<p>sub_keys &mdash; array to get mapcount data subkeys. …\n"],["mapcount_update","Roma::Client::Plugin::MapCount","Roma/Client/Plugin/MapCount.html#method-i-mapcount_update","(key, sub_keys = nil, expt = 0)","<p>update key expire (for JSON value)\n"],["mapcount_update_ms","Roma::Client::Plugin::MapCount","Roma/Client/Plugin/MapCount.html#method-i-mapcount_update_ms","(key, sub_keys = nil, expt = 0)","<p>update key expire (for Marshal value)\n"],["max_pool_size","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-max_pool_size","()","<p>get max pool size\n"],["max_pool_size=","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-max_pool_size-3D","(count)","<p>set max_pool_size\n"],["new","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-c-new","()",""],["new","Roma::Client::ClientRoutingTable","Roma/Client/ClientRoutingTable.html#method-c-new","(rd)",""],["new","Roma::Client::ConPool","Roma/Client/ConPool.html#method-c-new","(maxlength = 10, expire_time = 60)",""],["new","Roma::Client::Proxy::Conpool","Roma/Client/Proxy/Conpool.html#method-c-new","()",""],["new","Roma::Client::Proxy::Daemon","Roma/Client/Proxy/Daemon.html#method-c-new","(argv = nil)",""],["new","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-c-new","(ini_nodes, plugin_modules = nil, start_sync_routing_proc = true)","<p>ROMA client constractor .\n<p>ini_nodes &mdash; ROMA nodes array\n<p>plugin_modules &mdash; set plugin modules if you use .\n"],["new","Roma::Client::Sender","Roma/Client/Sender.html#method-c-new","()",""],["new","Roma::Client::Stats","Roma/Client/Stats.html#method-c-new","(stats_str)",""],["new","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-c-new","(logdev, shift_age = 0, shift_size = 1048576)",""],["new","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-c-new","(dgst_bits,div_bits,rn)",""],["new","Roma::Routing::RoutingData::RandomNodeListMaker","Roma/Routing/RoutingData/RandomNodeListMaker.html#method-c-new","(nodes,repethost)",""],["next_vnode","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-next_vnode","(vn)",""],["nodes","Roma::Client::ClientRoutingTable","Roma/Client/ClientRoutingTable.html#method-i-nodes","()",""],["out","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-out","(key)","<p>Delete value completely .\n<p>This method delete value completely. “completely” means Don&#39;t …\n"],["parse_log","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-parse_log","(t,line)",""],["plugin_modules","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-plugin_modules","()","<p>get plugin_modules\n"],["plugin_modules=","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-plugin_modules-3D","(modules)","<p>set plugin modules\n<p>You can set class Array.\n"],["pool_count","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-pool_count","()","<p>get pool count of clients\n"],["post_init","Roma::Client::Proxy::ClientHandler","Roma/Client/Proxy/ClientHandler.html#method-i-post_init","()",""],["post_init","Roma::Client::Proxy::RomaHandler","Roma/Client/Proxy/RomaHandler.html#method-i-post_init","()",""],["prepend","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-prepend","(key, val, expt = 0)","<p>Prepend value to exists string .\n<p>If same key exists in ROMA, this method prepend value . If same key\ndoesn&#39;t …\n"],["proc_failed","Roma::Client::ClientRoutingTable","Roma/Client/ClientRoutingTable.html#method-i-proc_failed","(nid)",""],["push_client","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-push_client","(client)","<p>push RomaClient instance\n"],["receive_data","Roma::Client::Proxy::ClientHandler","Roma/Client/Proxy/ClientHandler.html#method-i-receive_data","(data)",""],["release","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-release","()","<p>release all pool clients\n"],["release_all","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-c-release_all","()","<p>release all pool\n"],["replace","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-replace","(key, val, expt = 0, raw = false)","<p>Add value to ROMA .\n<p>If same key exists in ROMA, this method overwrite value . If same key\ndoesn&#39;t …\n"],["return_connection","Roma::Client::ConPool","Roma/Client/ConPool.html#method-i-return_connection","(ap, con)",""],["return_connection","Roma::Client::Proxy::Conpool","Roma/Client/Proxy/Conpool.html#method-i-return_connection","(con)",""],["rttable","Roma::Client::Proxy::Daemon","Roma/Client/Proxy/Daemon.html#method-c-rttable","()",""],["rttable_last_update","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-rttable_last_update","()",""],["save","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-save","(fname)",""],["search_mask","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-i-search_mask","()",""],["search_node","Roma::Client::ClientRoutingTable","Roma/Client/ClientRoutingTable.html#method-i-search_node","(key)",""],["search_nodes","Roma::Client::ClientRoutingTable","Roma/Client/ClientRoutingTable.html#method-i-search_nodes","(vn)","<p>Returns a node-is list at the vnode. <code>vn</code>: vnode-id\n"],["send_command","Roma::Client::Sender","Roma/Client/Sender.html#method-i-send_command","(nid, cmd, value = nil, receiver = :oneline_receiver)",""],["send_route_mklhash_command","Roma::Client::Sender","Roma/Client/Sender.html#method-i-send_route_mklhash_command","(node_id)",""],["send_routedump_command","Roma::Client::Sender","Roma/Client/Sender.html#method-i-send_routedump_command","(node_id)",""],["send_routedump_yaml_command","Roma::Client::Sender","Roma/Client/Sender.html#method-i-send_routedump_yaml_command","(node_id)",""],["send_stats_command","Roma::Client::Sender","Roma/Client/Sender.html#method-i-send_stats_command","(filter, node_id)",""],["send_verbosity_command","Roma::Client::Sender","Roma/Client/Sender.html#method-i-send_verbosity_command","(ap)",""],["send_version_command","Roma::Client::Sender","Roma/Client/Sender.html#method-i-send_version_command","(ap)",""],["set","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-set","(key, val, expt = 0, raw = false)","<p>Set value to ROMA .\n<p>Both same same key exists or not exists in ROMA, this method set value .\n<p>key &mdash; key for …\n"],["snapshot","Roma::Routing::RoutingData","Roma/Routing/RoutingData.html#method-c-snapshot","(fname)",""],["start","Roma::Client::Proxy::Daemon","Roma/Client/Proxy/Daemon.html#method-i-start","()",""],["stats","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-stats","(filter: \"\", node: @rttable.nodes.first)",""],["trace","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-trace","(progname = nil, &block)",""],["trace?","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-trace-3F","()",""],["unbind","Roma::Client::Proxy::ClientHandler","Roma/Client/Proxy/ClientHandler.html#method-i-unbind","()",""],["unbind","Roma::Client::Proxy::RomaHandler","Roma/Client/Proxy/RomaHandler.html#method-i-unbind","()",""],["unknown","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-unknown","(progname = nil, &block)",""],["update_rttable","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-update_rttable","(nodes = self.rttable.nodes)",""],["verbosity","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-verbosity","()",""],["version","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-version","()",""],["vnodes","Roma::Client::ClientRoutingTable","Roma/Client/ClientRoutingTable.html#method-i-vnodes","()",""],["warn","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-warn","(progname = nil, &block)",""],["warn?","Roma::Logging::RLogger","Roma/Logging/RLogger.html#method-i-warn-3F","()",""],["CHANGELOG","","CHANGELOG_md.html","","<p>0.4.3 (Aug 19 2015)\n<p>Change interface of Stat object and refactoring [Hiroki Matsue] 7438faf\n<p>Add tests for …\n"],["README","","README_md.html","","<p>ROMA Client for Ruby\n<p>ROMA is one of the data storing systems for distributed key-value stores in\nRuby …\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