diff options
Diffstat (limited to 'src/couchdb/couch_rep.erl')
-rw-r--r-- | src/couchdb/couch_rep.erl | 51 |
1 files changed, 29 insertions, 22 deletions
diff --git a/src/couchdb/couch_rep.erl b/src/couchdb/couch_rep.erl index f6fd0fad..0d914af0 100644 --- a/src/couchdb/couch_rep.erl +++ b/src/couchdb/couch_rep.erl @@ -48,37 +48,44 @@ replicate(Source, Target, Options) -> RepRecKey = ?LOCAL_DOC_PREFIX ++ HostName ++ ":" ++ Source ++ ":" ++ Target, StartTime = httpd_util:rfc1123_date(), - RepRecSrc = - case open_doc(DbSrc, RepRecKey, []) of - {ok, SrcDoc} -> SrcDoc; - _ -> #doc{id=RepRecKey} - end, - - RepRecTgt = - case open_doc(DbTgt, RepRecKey, []) of - {ok, TgtDoc} -> TgtDoc; - _ -> #doc{id=RepRecKey} + + case proplists:get_value(full, Options, false) + orelse proplists:get_value("full", Options, false) of + true -> + RepRecSrc = RepRecTgt = #doc{id=RepRecKey}; + false -> + RepRecSrc = + case open_doc(DbSrc, RepRecKey, []) of + {ok, SrcDoc} -> + ?LOG_DEBUG("Found existing replication record on source", []), + SrcDoc; + _ -> #doc{id=RepRecKey} + end, + + RepRecTgt = + case open_doc(DbTgt, RepRecKey, []) of + {ok, TgtDoc} -> + ?LOG_DEBUG("Found existing replication record on target", []), + TgtDoc; + _ -> #doc{id=RepRecKey} + end end, #doc{body={obj,OldRepHistoryProps}} = RepRecSrc, #doc{body={obj,OldRepHistoryPropsTrg}} = RepRecTgt, - SeqNum0 = + SeqNum = case OldRepHistoryProps == OldRepHistoryPropsTrg of true -> % if the records are identical, then we have a valid replication history proplists:get_value("source_last_seq", OldRepHistoryProps, 0); false -> + ?LOG_INFO("Replication records differ. " + "Performing full replication instead of incremental.", []), + ?LOG_DEBUG("Record on source:~p~nRecord on target:~p~n", [OldRepHistoryProps, OldRepHistoryPropsTrg]), 0 end, - SeqNum = - case proplists:get_value(full, Options, false) - orelse proplists:get_value("full", Options, false) of - true -> 0; - false -> SeqNum0 - end, - {NewSeqNum, Stats} = pull_rep(DbTgt, DbSrc, SeqNum), case NewSeqNum == SeqNum andalso OldRepHistoryProps /= [] of @@ -154,8 +161,8 @@ get_missing_revs_loop(Parent, DbTarget, OpenDocsPid, RevsChecked, MissingFound) RevsChecked + length(Changed), MissingFound + length(Missing)); shutdown -> - Parent ! {done, self(), [{missing_checked, RevsChecked}, - {missing_found, MissingFound}]} + Parent ! {done, self(), [{"missing_checked", RevsChecked}, + {"missing_found", MissingFound}]} end. @@ -168,7 +175,7 @@ open_doc_revs_loop(Parent, DbSource, SaveDocsPid, DocsRead) -> SaveDocsPid ! Docs, open_doc_revs_loop(Parent, DbSource, SaveDocsPid, DocsRead + length(Docs)); shutdown -> - Parent ! {done, self(), [{docs_read, DocsRead}]} + Parent ! {done, self(), [{"docs_read", DocsRead}]} end. @@ -187,7 +194,7 @@ save_docs_loop(Parent, DbTarget, DocsWritten) -> ok = save_docs(DbTarget, Docs, []), save_docs_loop(Parent, DbTarget, DocsWritten + length(Docs)); shutdown -> - Parent ! {done, self(), [{docs_written, DocsWritten}]} + Parent ! {done, self(), [{"docs_written", DocsWritten}]} end. |