Changeset 3 in code for trunk/lib/person.ml


Ignore:
Timestamp:
Apr 15, 2022, 1:17:01 PM (3 years ago)
Author:
fox
Message:
  • Removed 'txt init'

Format

  • New B32 ID

Index

  • New option: txt index --print
  • Move scheme to peers
  • Replace peer.*.conf files with index packed locations Instead of adding a URL to peers.*.conf, run txt pull <url>

Conversion

  • Rewritten converters
  • txt-convert looks for a .convert.conf containing key: value lines.
  • Specifiable topic-roots from .convert.conf.
  • Added Topics: key, with comma seperated topics.

If set only those topics will appear in the main index and used as topic roots.
Other topics will have sub-indices generated, but won't be listed in the main index.

  • HTML converter header & footer options
  • HTML-index renamed to HTM-index

Internal

  • Change types: uuid:Uuid -> id:string
  • File_store merges identical texts
  • Use peer ID for store path, store peers' texts in .local/share/texts
  • Simple URN resolution for converter

Continue to next feed if parsing one fails

  • Phasing-out Archive, replaced by improved packs
  • Eliminate Bos, Cohttp, lwt, uri, tls, Re, Ptime, dependencies
  • Lock version for Cmdliner, fix dune-project
  • Optional resursive store
  • Improve header_pack
  • Fix recursive mkdir
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/lib/person.ml

    r2 r3  
    11module Person = struct
    22  type name_t = string
    3   type address_t = Uri.t
     3  type address_t = string
    44  type t = { name: name_t; addresses: address_t list }
    55  let empty = { name = ""; addresses = [] }
    66  let compare = Stdlib.compare
    7   let to_string p = List.fold_left (fun a e -> a^" <"^Uri.to_string e^">") p.name p.addresses
     7  let name_to_string p = p.name
     8  let to_string p = List.fold_left (fun a e -> Printf.sprintf "%s <%s>" a e) p.name p.addresses
    89  let of_string s = match String.trim s with "" -> empty | s ->
    9     match Re.Str.(split (regexp " *< *") s) with
     10    match Str.(split (regexp " *< *") s) with
    1011    | [] -> empty
    1112    | [n] -> let name = String.trim n in { empty with name }
    1213    | n::adds ->
    1314      let name = String.trim n in
    14       let addresses = List.map (fun f -> Uri.of_string @@ String.(sub f 0 (length f -1))) adds in
     15      let addresses = List.map (fun f -> String.(sub f 0 (length f -1))) adds in
    1516      { name; addresses }
    1617end
     
    2021module Set = struct
    2122  include Set.Make(Person)
    22   let to_string ?(pre="") ?(sep=", ") s =
    23     let str = Person.to_string in
     23  let to_string ?(names_only=false) ?(pre="") ?(sep=", ") s =
     24    let str = if names_only then Person.name_to_string else Person.to_string in
    2425    let j x a = match a, x with "",_ -> str x | _,x when x = Person.empty -> a | _ -> a^sep^str x in
    2526    fold j s pre
Note: See TracChangeset for help on using the changeset viewer.