package core_kernel

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Source file host_and_port.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
module Stable = struct
  open Stable_internal
  open Ppx_compare_lib.Builtin

  module V1 = struct
    module Serializable = struct
      type t = string * int [@@deriving sexp, bin_io]
    end

    module T = struct
      type t =
        { host : string
        ; port : int
        }
      [@@deriving compare, hash]

      let to_serializable { host; port } = host, port
      let of_serializable (host, port) = { host; port }
    end

    include T

    include Binable.Stable.Of_binable.V1 [@alert "-legacy"]
        (Serializable)
        (struct
          include T

          let to_binable = to_serializable
          let of_binable = of_serializable
        end)

    let%expect_test "stable" =
      print_endline [%bin_digest: t];
      print_endline [%bin_digest: Serializable.t];
      [%expect
        {|
                  957990f0fc4161fb874e66872550fb40
                  957990f0fc4161fb874e66872550fb40 |}]
    ;;

    include Sexpable.Stable.Of_sexpable.V1
        (Serializable)
        (struct
          include T

          let to_sexpable = to_serializable
          let of_sexpable = of_serializable
        end)

    open! Import
    open! Std_internal
    open! T

    let to_string { host; port } = sprintf "%s:%d" host port

    let of_string s =
      match String.split s ~on:':' with
      | [ host; port ] ->
        let port =
          try Int.of_string port with
          | _exn -> failwithf "Host_and_port.of_string: bad port: %s" s ()
        in
        { host; port }
      | _ -> failwithf "Host_and_port.of_string: %s" s ()
    ;;

    let t_of_sexp = function
      | Sexp.Atom s as sexp ->
        (try of_string s with
         | Failure err -> of_sexp_error err sexp)
      | sexp -> t_of_sexp sexp
    ;;

    let%test_unit "t_of_sexp" =
      [%test_result: t]
        (t_of_sexp (Sexp.of_string {|(localhost 8080)|}))
        ~expect:{ host = "localhost"; port = 8080 };
      [%test_result: t]
        (t_of_sexp (Sexp.of_string {|localhost:8080|}))
        ~expect:{ host = "localhost"; port = 8080 }
    ;;

    let%test_unit "sexp roundtrip" =
      let open Quickcheck.Let_syntax in
      Quickcheck.test
        (let%map host = String.quickcheck_generator
         and port = Int.quickcheck_generator in
         { host; port })
        ~f:(fun t -> [%test_result: t] (t_of_sexp (sexp_of_t t)) ~expect:t)
    ;;
  end
end

open! Import
open! Std_internal

module Latest = struct
  include Stable.V1
end

include Latest

let create ~host ~port = { host; port }
let host t = t.host
let port t = t.port
let tuple t = to_serializable t

include Pretty_printer.Register (struct
    type nonrec t = t

    let to_string = to_string
    let module_name = "Core_kernel.Host_and_port"
  end)

include (Hashable.Make_binable (Latest) : Hashable.S_binable with type t := t)
include Comparable.Make_binable (Latest)

let type_id = Type_equal.Id.create ~name:"Host_and_port" sexp_of_t