summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--README.md2
-rw-r--r--apps/couch/src/couch_db.erl8
-rw-r--r--apps/couch/src/couch_view_group.erl15
3 files changed, 21 insertions, 4 deletions
diff --git a/README.md b/README.md
index b6fb1a42..5a774c98 100644
--- a/README.md
+++ b/README.md
@@ -15,7 +15,7 @@ Clusters behave according to concepts outlined in [Amazon's Dynamo paper][4], na
BigCouch has the same dependencies as CouchDB:
- * Erlang (R13B03 or higher)
+ * Erlang (R13B03 or higher) (R14B01 or higher to build a release)
* ICU (4.2 is preferable)
* Spidermonkey (1.9.2 preferable, [https://launchpad.net/~commonjs/+archive/ppa/][6])
* LibCurl (7.18 or higher)
diff --git a/apps/couch/src/couch_db.erl b/apps/couch/src/couch_db.erl
index e8a0824c..96c49886 100644
--- a/apps/couch/src/couch_db.erl
+++ b/apps/couch/src/couch_db.erl
@@ -112,8 +112,12 @@ open_ref_counted(MainPid, OpenedPid) ->
gen_server:call(MainPid, {open_ref_count, OpenedPid}).
is_idle(#db{compactor_pid=nil, waiting_delayed_commit=nil} = Db) ->
- {monitored_by, Pids} = erlang:process_info(Db#db.fd, monitored_by),
- (Pids -- [Db#db.main_pid, whereis(couch_stats_collector)]) =:= [];
+ case erlang:process_info(Db#db.fd, monitored_by) of
+ undefined ->
+ true;
+ {monitored_by, Pids} ->
+ (Pids -- [Db#db.main_pid, whereis(couch_stats_collector)]) =:= []
+ end;
is_idle(_Db) ->
false.
diff --git a/apps/couch/src/couch_view_group.erl b/apps/couch/src/couch_view_group.erl
index e6fac237..11cb4c60 100644
--- a/apps/couch/src/couch_view_group.erl
+++ b/apps/couch/src/couch_view_group.erl
@@ -14,7 +14,7 @@
-behaviour(gen_server).
%% API
--export([start_link/1, request_group/2, request_group_info/1]).
+-export([start_link/1, request_group/2, trigger_group_update/2, request_group_info/1]).
-export([open_db_group/2, open_temp_group/5, design_doc_to_view_group/1,design_root/2]).
%% gen_server callbacks
@@ -54,6 +54,9 @@ request_group_info(Pid) ->
throw(Error)
end.
+trigger_group_update(Pid, RequestSeq) ->
+ gen_server:cast(Pid, {update_group, RequestSeq}).
+
% from template
start_link(InitArgs) ->
case gen_server:start_link(couch_view_group,
@@ -153,6 +156,16 @@ handle_call(request_group_info, _From, State) ->
GroupInfo = get_group_info(State),
{reply, {ok, GroupInfo}, State}.
+handle_cast({update_group, RequestSeq},
+ #group_state{
+ group=#group{current_seq=Seq}=Group,
+ updater_pid=nil}=State) when RequestSeq > Seq ->
+ Owner = self(),
+ Pid = spawn_link(fun()-> couch_view_updater:update(Owner, Group) end),
+ {noreply, State#group_state{updater_pid=Pid}};
+handle_cast({update_group, _RequestSeq}, State) ->
+ {noreply, State};
+
handle_cast({start_compact, CompactFun}, #group_state{compactor_pid=nil}
= State) ->
#group_state{