| 1 | open Logarion | 
|---|
| 2 |  | 
|---|
| 3 | module Rel = struct | 
|---|
| 4 |  | 
|---|
| 5 | module Rel_set = Set.Make(String) | 
|---|
| 6 | module Id_map = Map.Make(String) | 
|---|
| 7 |  | 
|---|
| 8 | type t = { last_rel: string; ref_set: String_set.t; rep_set: String_set.t } | 
|---|
| 9 | type map_t = t Id_map.t | 
|---|
| 10 |  | 
|---|
| 11 | let empty = { last_rel = ""; ref_set = Rel_set.empty; rep_set = Rel_set.empty } | 
|---|
| 12 | let empty_map = Id_map.empty | 
|---|
| 13 |  | 
|---|
| 14 | let acc_ref date source target = Id_map.update target (function | 
|---|
| 15 | | None -> Some { last_rel = date; | 
|---|
| 16 | ref_set = Rel_set.singleton source; | 
|---|
| 17 | rep_set = Rel_set.empty } | 
|---|
| 18 | | Some rel -> Some { rel with | 
|---|
| 19 | last_rel = if Date.compare date rel.last_rel > 0 then date else rel.last_rel; | 
|---|
| 20 | ref_set = Rel_set.add source rel.ref_set }) | 
|---|
| 21 |  | 
|---|
| 22 | let acc_rep date source target = Id_map.update target (function | 
|---|
| 23 | | None -> Some { last_rel = date; | 
|---|
| 24 | rep_set = Rel_set.singleton source; | 
|---|
| 25 | ref_set = Rel_set.empty } | 
|---|
| 26 | | Some rel -> Some { rel with | 
|---|
| 27 | last_rel = if Date.compare date rel.last_rel > 0 then date else rel.last_rel; | 
|---|
| 28 | rep_set = Rel_set.add source rel.rep_set }) | 
|---|
| 29 |  | 
|---|
| 30 | let acc_txt rels (text, _paths) = | 
|---|
| 31 | let acc_ref = acc_ref (Date.listing text.Text.date) text.Text.id in | 
|---|
| 32 | let acc_rep = acc_rep (Date.listing text.Text.date) text.Text.id in | 
|---|
| 33 | let rels = String_set.fold acc_ref (Text.set "references" text) rels in | 
|---|
| 34 | let rels = String_set.fold acc_rep (Text.set "in-reply-to" text) rels in | 
|---|
| 35 | rels | 
|---|
| 36 |  | 
|---|
| 37 | let acc_pck rels peer = | 
|---|
| 38 | let path = try List.hd peer.Peers.pack.Header_pack.info.locations with Failure _->"" in | 
|---|
| 39 | try Header_pack.fold | 
|---|
| 40 | (fun rels id t _title _authors _topics refs_ls reps_ls -> | 
|---|
| 41 | let acc_ref = acc_ref (Date.of_secs @@ Int32.to_int t) (Filename.concat path id) in | 
|---|
| 42 | let acc_rep = acc_rep (Date.of_secs @@ Int32.to_int t) (Filename.concat path id) in | 
|---|
| 43 | let rels = String_set.fold acc_ref (String_set.of_list refs_ls) rels in | 
|---|
| 44 | let rels = String_set.fold acc_rep (String_set.of_list reps_ls) rels in | 
|---|
| 45 | rels) | 
|---|
| 46 | rels peer.Peers.pack | 
|---|
| 47 | with e -> prerr_endline "acc_pck"; raise e | 
|---|
| 48 | end | 
|---|
| 49 |  | 
|---|
| 50 |  | 
|---|
| 51 | type t = { | 
|---|
| 52 | id: string; | 
|---|
| 53 | dir: string; | 
|---|
| 54 | kv: string Store.KV.t; | 
|---|
| 55 | topic_roots: string list; | 
|---|
| 56 | topics: (String_set.t * String_set.t) Topic_set.Map.t; | 
|---|
| 57 | relations: Rel.map_t; | 
|---|
| 58 | texts: Text.t list | 
|---|
| 59 | } | 
|---|
| 60 |  | 
|---|
| 61 | type fn_t = { | 
|---|
| 62 | ext: string; | 
|---|
| 63 | page: (t -> Logarion.Text.t -> string) option; | 
|---|
| 64 | indices: (t -> unit) option; | 
|---|
| 65 | } | 
|---|
| 66 |  | 
|---|
| 67 | let empty () = { | 
|---|
| 68 | id = ""; dir = ""; | 
|---|
| 69 | kv = Store.KV.empty; | 
|---|
| 70 | topic_roots = []; | 
|---|
| 71 | topics = Topic_set.Map.empty; | 
|---|
| 72 | relations = Rel.Id_map.empty; | 
|---|
| 73 | texts = [] | 
|---|
| 74 | } | 
|---|