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.
- checksums.yaml +4 -4
- data/{CHANGELOG → CHANGELOG.md} +8 -5
- data/Gemfile.lock +23 -15
- data/README.md +62 -0
- data/Rakefile +3 -3
- data/doc/CHANGELOG_md.html +119 -0
- data/doc/README_md.html +161 -0
- data/doc/Roma/Client/ClientPool.html +716 -0
- data/doc/Roma/Client/ClientRoutingTable.html +495 -0
- data/doc/Roma/Client/ConPool.html +484 -0
- data/doc/Roma/Client/Plugin/Alist.html +1276 -0
- data/doc/Roma/Client/Plugin/Map.html +531 -0
- data/doc/Roma/Client/Plugin/MapCount.html +401 -0
- data/doc/Roma/Client/Plugin.html +95 -0
- data/doc/Roma/Client/Proxy/ClientHandler.html +273 -0
- data/doc/Roma/Client/Proxy/Conpool.html +394 -0
- data/doc/Roma/Client/Proxy/Daemon.html +305 -0
- data/doc/Roma/Client/Proxy/RomaHandler.html +217 -0
- data/doc/Roma/Client/Proxy.html +95 -0
- data/doc/Roma/Client/RomaClient.html +1339 -0
- data/doc/Roma/Client/Sender.html +482 -0
- data/doc/Roma/Client/Stats.html +162 -0
- data/doc/Roma/Client/VERSION.html +141 -0
- data/doc/Roma/Client.html +95 -0
- data/doc/Roma/Logging/RLogger/ExtLogDev.html +159 -0
- data/doc/Roma/Logging/RLogger/ExtShiftAge.html +95 -0
- data/doc/Roma/Logging/RLogger/ExtTrace.html +109 -0
- data/doc/Roma/Logging/RLogger/Severity.html +139 -0
- data/doc/Roma/Logging/RLogger.html +786 -0
- data/doc/Roma/Logging.html +95 -0
- data/doc/Roma/Routing/RoutingData/RandomNodeListMaker.html +311 -0
- data/doc/Roma/Routing/RoutingData.html +912 -0
- data/doc/Roma/Routing.html +95 -0
- data/doc/Roma.html +95 -0
- data/doc/created.rid +20 -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 +210 -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 +972 -0
- data/lib/roma/client/rclient.rb +2 -1
- data/lib/roma/client/sender.rb +2 -2
- data/lib/roma/client/version.rb +1 -1
- data/lib/roma/client.rb +0 -21
- metadata +84 -10
- 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 #=> “2” …\n"],["Roma::Client::VERSION","","Roma/Client/VERSION.html","","<p>What Is This Library?\n<p>ROMA client proxy daemon'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 — 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'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'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 — key for cas .\n<p>value — store value .\n"],["client","Roma::Client::ClientPool","Roma/Client/ClientPool.html#method-i-client","()","<p>get RomaClient instance\n<p>type — RomaClient instance group.\n<p>return — 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 — key for decremental .\n<p>val — decremental value .\n"],["delete","Roma::Client::RomaClient","Roma/Client/RomaClient.html#method-i-delete","(key)","<p>Delete value .\n<p>key — key for delete .\n<p>return — 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 — key for get .\n<p>raw — If you set this value true, value isn'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 — 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 — exceptional hosts(ex.)\n<p>exp_nodes — 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 — ignore\n<p>exp_nodes — 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 — key array for get .\n<p>raw — If you set this value true, value isn'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 — key for incremental .\n<p>val — 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 — 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 — 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 — key to count up data\n<p>sub_keys — sub keys to count up. You can set String 'sk', …\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 — key to count up data\n<p>sub_keys — 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 — key to get mapcount data\n<p>sub_keys — 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 — key to get mapcount data\n<p>sub_keys — 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 — ROMA nodes array\n<p>plugin_modules — 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'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'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'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 — 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
|
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
|