diff --git a/.gitignore b/.gitignore index 68b8919..cb71ec5 100644 --- a/.gitignore +++ b/.gitignore @@ -11,3 +11,5 @@ _tests lib_test/files zpipe c/dpipe +*.install +*~ diff --git a/.travis.yml b/.travis.yml index da079b5..df9d9e0 100644 --- a/.travis.yml +++ b/.travis.yml @@ -8,8 +8,10 @@ env: matrix: - PACKAGE="digestif" OCAML_VERSION=4.03 TESTS=false - - PACKAGE="digestif-test-c" OCAML_VERSION=4.03 INSTALL=false TESTS=true - PINS=$(if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then echo -n "digestif:https://github.com/$TRAVIS_PULL_REQUEST_SLUG.git"; if [ ! -z $TRAVIS_PULL_REQUEST_BRANCH ]; then echo -n "#$TRAVIS_PULL_REQUEST_BRANCH"; fi else echo -n "digestif:https://github.com/$TRAVIS_REPO_SLUG.git"; if [ ! -z $TRAVIS_BRANCH ]; then echo -n "#$TRAVIS_BRANCH"; fi fi) + - PACKAGE="digestif" OCAML_VERSION=4.03 INSTALL=false + PINS="digestif-test-c:test" + EXTRA_DEPS="digestif-test-c" - - PACKAGE="digestif-test-ocaml" OCAML_VERSION=4.03 INSTALL=false TESTS=true - PINS=$(if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then echo -n "digestif:https://github.com/$TRAVIS_PULL_REQUEST_SLUG.git"; if [ ! -z $TRAVIS_PULL_REQUEST_BRANCH ]; then echo -n "#$TRAVIS_PULL_REQUEST_BRANCH"; fi else echo -n "digestif:https://github.com/$TRAVIS_REPO_SLUG.git"; if [ ! -z $TRAVIS_BRANCH ]; then echo -n "#$TRAVIS_BRANCH"; fi fi) + - PACKAGE="digestif" OCAML_VERSION=4.03 INSTALL=false + PINS="digestif-test-ocaml:test" + EXTRA_DEPS="digestif-test-ocaml" diff --git a/_tags b/_tags index c0e16d2..17594ff 100644 --- a/_tags +++ b/_tags @@ -1,7 +1,7 @@ true: safe_string, bin_annot -# : include (not needed to the binary test) -: record_digestif_rakia_stubs +: include +: record_digestif_rakia_stubs : link_digestif_rakia_stubs, use_bigarray : use_bigarray : package(alcotest), package(cstruct) diff --git a/pkg/META b/pkg/META index c810e4a..5cacdac 100644 --- a/pkg/META +++ b/pkg/META @@ -1,27 +1,31 @@ version = "%%VERSION%%" requires = "bigarray" description = "Interface of the library" +archive(byte) = "digestif.cma" +archive(native) = "digestif.cmxa" +plugin(byte) = "digestif.cma" +plugin(native) = "digestif.cmxs" package "c" ( directory = "c" version = "%%VERSION%%" description = "Implementation of hash function in C" - requires = "bigarray" - archive(byte) = "digestif.cma" - archive(native) = "digestif.cmxa" - plugin(byte) = "digestif.cma" - plugin(native) = "digestif.cmxs" - exists_if = "digestif.cma" + requires = "bigarray digestif" + archive(byte) = "digestif-c.cma" + archive(native) = "digestif-c.cmxa" + plugin(byte) = "digestif-c.cma" + plugin(native) = "digestif-c.cmxs" + exists_if = "digestif-c.cma" ) package "ocaml" ( directory = "ocaml" version = "%%VERSION%%" description = "Implementation of hash function in OCaml" - requires = "bigarray" - archive(byte) = "digestif.cma" - archive(native) = "digestif.cmxa" - plugin(byte) = "digestif.cma" - plugin(native) = "digestif.cmxs" - exists_if = "digestif.cma" + requires = "bigarray digestif" + archive(byte) = "digestif-ocaml.cma" + archive(native) = "digestif-ocaml.cmxa" + plugin(byte) = "digestif-ocaml.cma" + plugin(native) = "digestif-ocaml.cmxs" + exists_if = "digestif-ocaml.cma" ) diff --git a/pkg/pkg.ml b/pkg/pkg.ml index 71c8ef2..60d68ae 100644 --- a/pkg/pkg.ml +++ b/pkg/pkg.ml @@ -16,6 +16,7 @@ let () = ; Pkg.doc "CHANGES.md" ; Pkg.clib "src-c/librakia_stubs.clib" ~lib_dst_dir:"c" - ; Pkg.lib "common/digestif.cmi" ~dst:"digestif.cmi" - ; Pkg.mllib ~api:["Digestif"] "src-c/digestif.mllib" ~dst_dir:"c" - ; Pkg.mllib ~api:["Digestif"] "src-ocaml/digestif.mllib" ~dst_dir:"ocaml" ] + ; Pkg.lib "src/digestif_sig.cmi" ~dst:"digestif_sig.cmi" + ; Pkg.mllib "src/digestif.mllib" + ; Pkg.mllib ~api:["Digestif"] "src-c/digestif-c.mllib" ~dst_dir:"c" + ; Pkg.mllib ~api:["Digestif"] "src-ocaml/digestif-ocaml.mllib" ~dst_dir:"ocaml" ] diff --git a/src-c/digestif-c.mllib b/src-c/digestif-c.mllib new file mode 100644 index 0000000..7e6a6f0 --- /dev/null +++ b/src-c/digestif-c.mllib @@ -0,0 +1,2 @@ +Digestif +Rakia_native \ No newline at end of file diff --git a/src-c/digestif.ml b/src-c/digestif.ml index b8f4bab..7b63b1e 100644 --- a/src-c/digestif.ml +++ b/src-c/digestif.ml @@ -1,67 +1,12 @@ +module type S = Digestif_sig.S +module type T = Digestif_sig.T + module Bi = Digestif_bigstring module By = Digestif_bytes module Pp = Digestif_pp module Native = Rakia_native -module type S = -sig - val digest_size : int - - module Bigstring : - sig - type buffer = Native.ba - type ctx - type t = Native.ba - - val init : unit -> ctx - val feed : ctx -> buffer -> unit - val feed_bytes : ctx -> By.t -> unit - val feed_bigstring : ctx -> Bi.t -> unit - val get : ctx -> t - - val digest : buffer -> t - val digestv : buffer list -> t - val hmac : key:buffer -> buffer -> t - val hmacv : key:buffer -> buffer list -> t - - val compare : t -> t -> int - val eq : t -> t -> bool - val neq : t -> t -> bool - - val pp : Format.formatter -> t -> unit - val of_hex : buffer -> t - val to_hex : t -> buffer - end - - module Bytes : - sig - type buffer = Native.st - type ctx - type t = Native.st - - val init : unit -> ctx - val feed : ctx -> buffer -> unit - val feed_bytes : ctx -> By.t -> unit - val feed_bigstring : ctx -> Bi.t -> unit - val get : ctx -> t - - val digest : buffer -> t - val digestv : buffer list -> t - val hmac : key:buffer -> buffer -> t - val hmacv : key:buffer -> buffer list -> t - - val compare : t -> t -> int - val eq : t -> t -> bool - val neq : t -> t -> bool - - val pp : Format.formatter -> t -> unit - val of_hex : buffer -> t - val to_hex : t -> buffer - end -end - -module type Foreign = -sig +module type Foreign = sig open Native module Bigstring : @@ -87,8 +32,7 @@ sig val digest_size : int end -module type Convenience = -sig +module type Convenience = sig type t val compare : t -> t -> int @@ -96,8 +40,7 @@ sig val neq : t -> t -> bool end -module Core (F : Foreign) (D : Desc) = -struct +module Core (F : Foreign) (D : Desc) = struct let block_size = D.block_size and digest_size = D.digest_size and ctx_size = F.ctx_size () @@ -134,8 +77,7 @@ struct let t = init () in ( List.iter (feed t) bufs; get t ) end - module Bigstring = - struct + module Bigstring = struct type buffer = Native.ba type ctx = Native.ctx @@ -167,8 +109,7 @@ struct end end -module Make (F : Foreign) (D : Desc) = -struct +module Make (F : Foreign) (D : Desc) = struct type ctx = Native.ctx module C = Core (F) (D) @@ -199,8 +140,7 @@ struct let hmac ~key msg = hmacv ~key [ msg ] end - module Bigstring = - struct + module Bigstring = struct include C.Bigstring let opad = Bi.init C.block_size (fun _ -> '\x5c') @@ -222,8 +162,7 @@ struct end end -module type ForeignExt = -sig +module type ForeignExt = sig open Native module Bigstring : @@ -246,8 +185,7 @@ sig val key_size : unit -> int end -module Make_BLAKE2 (F : ForeignExt) (D : Desc) : S = -struct +module Make_BLAKE2 (F : ForeignExt) (D : Desc) : Digestif_sig.S = struct let block_size = D.block_size and digest_size = D.digest_size and ctx_size = F.ctx_size () @@ -296,8 +234,7 @@ struct hmacv ~key [ msg ] end - module Bigstring = - struct + module Bigstring = struct type buffer = Native.ba type ctx = Native.ctx @@ -353,16 +290,7 @@ module BLAKE2B = Make_BLAKE2(Native.BLAKE2B) (struct let (digest_size, block_siz module BLAKE2S = Make_BLAKE2(Native.BLAKE2S) (struct let (digest_size, block_size) = (32, 64) end) module RMD160 : S = Make (Native.RMD160) (struct let (digest_size, block_size) = (20, 64) end) -type hash = - [ `MD5 - | `SHA1 - | `SHA224 - | `SHA256 - | `SHA384 - | `SHA512 - | `BLAKE2B - | `BLAKE2S - | `RMD160 ] +type hash = Digestif_sig.hash let module_of = function | `MD5 -> (module MD5 : S) @@ -375,8 +303,10 @@ let module_of = function | `BLAKE2S -> (module BLAKE2S : S) | `RMD160 -> (module RMD160 : S) -module Bytes = -struct +module Bytes = struct + type t = Bytes.t + type buffer = Bytes.t + let digest hash = let module H = (val (module_of hash)) in H.Bytes.digest @@ -406,8 +336,10 @@ struct H.Bytes.pp end -module Bigstring = -struct +module Bigstring = struct + type t = Bi.t + type buffer = Bi.t + let digest hash = let module H = (val (module_of hash)) in H.Bigstring.digest diff --git a/src-c/digestif.mli b/src-c/digestif.mli deleted file mode 120000 index e5206f2..0000000 --- a/src-c/digestif.mli +++ /dev/null @@ -1 +0,0 @@ -../common/digestif.mli \ No newline at end of file diff --git a/src-c/digestif.mli b/src-c/digestif.mli new file mode 100644 index 0000000..318430d --- /dev/null +++ b/src-c/digestif.mli @@ -0,0 +1,23 @@ +module type S = Digestif_sig.S +module type T = Digestif_sig.T + +type hash = Digestif_sig.hash + +val digest_size : hash -> int + +module MD5 : S +module SHA1 : S +module SHA224 : S +module SHA256 : S +module SHA384 : S +module SHA512 : S +module BLAKE2B : S +module BLAKE2S : S +module RMD160 : S + +module Bytes : T + with type t = Bytes.t + and type buffer = Bytes.t +module Bigstring : T + with type t = Digestif_sig.Bigstring.t + and type buffer = Digestif_sig.Bigstring.t diff --git a/src-c/digestif.mllib b/src-c/digestif.mllib deleted file mode 100644 index 741b846..0000000 --- a/src-c/digestif.mllib +++ /dev/null @@ -1,5 +0,0 @@ -Digestif -Digestif_pp -Digestif_bytes -Digestif_bigstring -Rakia_native \ No newline at end of file diff --git a/src-c/digestif_bigstring.ml b/src-c/digestif_bigstring.ml deleted file mode 120000 index b235589..0000000 --- a/src-c/digestif_bigstring.ml +++ /dev/null @@ -1 +0,0 @@ -../common/digestif_bigstring.ml \ No newline at end of file diff --git a/src-c/digestif_bytes.ml b/src-c/digestif_bytes.ml deleted file mode 120000 index 8c3ae79..0000000 --- a/src-c/digestif_bytes.ml +++ /dev/null @@ -1 +0,0 @@ -../common/digestif_bytes.ml \ No newline at end of file diff --git a/src-c/digestif_pp.ml b/src-c/digestif_pp.ml deleted file mode 120000 index ab8959f..0000000 --- a/src-c/digestif_pp.ml +++ /dev/null @@ -1 +0,0 @@ -../common/digestif_pp.ml \ No newline at end of file diff --git a/src-ocaml/digestif.mllib b/src-ocaml/digestif-ocaml.mllib similarity index 77% rename from src-ocaml/digestif.mllib rename to src-ocaml/digestif-ocaml.mllib index 5510a28..e279451 100644 --- a/src-ocaml/digestif.mllib +++ b/src-ocaml/digestif-ocaml.mllib @@ -1,7 +1,4 @@ Digestif -Digestif_pp -Digestif_bytes -Digestif_bigstring Baijiu_xor Baijiu_buffer Baijiu_sha1 diff --git a/src-ocaml/digestif.ml b/src-ocaml/digestif.ml index 8aac790..9ade085 100644 --- a/src-ocaml/digestif.ml +++ b/src-ocaml/digestif.ml @@ -3,62 +3,8 @@ module By = Digestif_bytes module Pp = Digestif_pp module Xor = Baijiu_xor -module type S = -sig - val digest_size : int - - module Bigstring : - sig - type buffer = Bi.t - type ctx - type t = Bi.t - - val init : unit -> ctx - val feed : ctx -> buffer -> unit - val feed_bytes : ctx -> Bytes.t -> unit - val feed_bigstring : ctx -> Bi.t -> unit - val get : ctx -> t - - val digest : buffer -> t - val digestv : buffer list -> t - val hmac : key:buffer -> buffer -> t - val hmacv : key:buffer -> buffer list -> t - - val compare : t -> t -> int - val eq : t -> t -> bool - val neq : t -> t -> bool - - val pp : Format.formatter -> t -> unit - val of_hex : buffer -> t - val to_hex : t -> buffer - end - - module Bytes : - sig - type buffer = By.t - type ctx - type t = By.t - - val init : unit -> ctx - val feed : ctx -> buffer -> unit - val feed_bytes : ctx -> Bytes.t -> unit - val feed_bigstring : ctx -> Bi.t -> unit - val get : ctx -> t - - val digest : buffer -> t - val digestv : buffer list -> t - val hmac : key:buffer -> buffer -> t - val hmacv : key:buffer -> buffer list -> t - - val compare : t -> t -> int - val eq : t -> t -> bool - val neq : t -> t -> bool - - val pp : Format.formatter -> t -> unit - val of_hex : buffer -> t - val to_hex : t -> buffer - end -end +module type S = Digestif_sig.S +module type T = Digestif_sig.T module type Desc = sig @@ -321,6 +267,9 @@ let module_of = function module Bytes = struct + type t = Bytes.t + type buffer = Bytes.t + let digest hash = let module H = (val (module_of hash)) in H.Bytes.digest @@ -352,6 +301,9 @@ end module Bigstring = struct + type t = Bi.t + type buffer = Bi.t + let digest hash = let module H = (val (module_of hash)) in H.Bigstring.digest diff --git a/src-ocaml/digestif.mli b/src-ocaml/digestif.mli deleted file mode 120000 index e5206f2..0000000 --- a/src-ocaml/digestif.mli +++ /dev/null @@ -1 +0,0 @@ -../common/digestif.mli \ No newline at end of file diff --git a/src-ocaml/digestif.mli b/src-ocaml/digestif.mli new file mode 100644 index 0000000..318430d --- /dev/null +++ b/src-ocaml/digestif.mli @@ -0,0 +1,23 @@ +module type S = Digestif_sig.S +module type T = Digestif_sig.T + +type hash = Digestif_sig.hash + +val digest_size : hash -> int + +module MD5 : S +module SHA1 : S +module SHA224 : S +module SHA256 : S +module SHA384 : S +module SHA512 : S +module BLAKE2B : S +module BLAKE2S : S +module RMD160 : S + +module Bytes : T + with type t = Bytes.t + and type buffer = Bytes.t +module Bigstring : T + with type t = Digestif_sig.Bigstring.t + and type buffer = Digestif_sig.Bigstring.t diff --git a/src-ocaml/digestif_bigstring.ml b/src-ocaml/digestif_bigstring.ml deleted file mode 120000 index b235589..0000000 --- a/src-ocaml/digestif_bigstring.ml +++ /dev/null @@ -1 +0,0 @@ -../common/digestif_bigstring.ml \ No newline at end of file diff --git a/src-ocaml/digestif_bytes.ml b/src-ocaml/digestif_bytes.ml deleted file mode 120000 index 8c3ae79..0000000 --- a/src-ocaml/digestif_bytes.ml +++ /dev/null @@ -1 +0,0 @@ -../common/digestif_bytes.ml \ No newline at end of file diff --git a/src-ocaml/digestif_pp.ml b/src-ocaml/digestif_pp.ml deleted file mode 120000 index ab8959f..0000000 --- a/src-ocaml/digestif_pp.ml +++ /dev/null @@ -1 +0,0 @@ -../common/digestif_pp.ml \ No newline at end of file diff --git a/common/digestif.mllib b/src/digestif.mllib similarity index 83% rename from common/digestif.mllib rename to src/digestif.mllib index fa6e4d3..096528d 100644 --- a/common/digestif.mllib +++ b/src/digestif.mllib @@ -1,4 +1,3 @@ -Digestif Digestif_pp Digestif_bytes Digestif_bigstring diff --git a/common/digestif_bigstring.ml b/src/digestif_bigstring.ml similarity index 100% rename from common/digestif_bigstring.ml rename to src/digestif_bigstring.ml diff --git a/src/digestif_bigstring.mli b/src/digestif_bigstring.mli new file mode 100644 index 0000000..8ba4355 --- /dev/null +++ b/src/digestif_bigstring.mli @@ -0,0 +1,52 @@ +open Bigarray +type t = (char, int8_unsigned_elt, c_layout) Array1.t +val length: t -> int +val create: int -> t +val get: t -> int -> char +val set: t -> int -> char -> unit +val sub: t -> int -> int -> t +val init: int -> (int -> char) -> t +val fill: t -> int -> int -> char -> unit +val copy: t -> t +val get_u8: t -> int -> int +external get_u16: t -> int -> int = "%caml_bigstring_get16u" +external get_u32: t -> int -> int32 = "%caml_bigstring_get32u" +external get_u64: t -> int -> int64 = "%caml_bigstring_get64u" +val get_nat: t -> int -> nativeint +val set_u8: t -> int -> int -> unit +external set_u16: t -> int -> int -> unit = "%caml_bigstring_set16u" +external set_u32: t -> int -> int32 -> unit = "%caml_bigstring_set32u" +external set_u64: t -> int -> int64 -> unit = "%caml_bigstring_set64u" +val set_nat: t -> int -> nativeint -> unit +val to_string: t -> string +val blit: t -> int -> t -> int -> int -> unit +val blit_from_bytes: bytes -> int -> t -> int -> int -> unit +val blit_from_bigstring: t -> int -> t -> int -> int -> unit +val rpad: t -> int -> char -> t +val pp: Format.formatter -> t -> unit +val compare: t -> t -> int +val eq: t -> t -> bool +val neq: t -> t -> bool +val iter: (char -> unit) -> t -> unit +val empty: t +external swap32: int32 -> int32 = "%bswap_int32" +external swap64: int64 -> int64 = "%bswap_int64" +external swapnat: nativeint -> nativeint = "%bswap_native" +val cpu_to_be32: t -> int -> int32 -> unit +val cpu_to_le32: t -> int -> int32 -> unit +val cpu_to_be64: t -> int -> int64 -> unit +val cpu_to_le64: t -> int -> int64 -> unit +val be32_to_cpu: t -> int -> int32 +val be32_from_bigstring_to_cpu: t -> int -> int32 +val be32_from_bytes_to_cpu: Bytes.t -> int -> int32 +val le32_to_cpu: t -> int -> int32 +val le32_from_bigstring_to_cpu: t -> int -> int32 +val le32_from_bytes_to_cpu: Bytes.t -> int -> int32 +val be64_to_cpu: t -> int -> int64 +val be64_from_bigstring_to_cpu: t -> int -> int64 +val be64_from_bytes_to_cpu: Bytes.t -> int -> int64 +val le64_to_cpu: t -> int -> int64 +val le64_from_bigstring_to_cpu: t -> int -> int64 +val le64_from_bytes_to_cpu: Bytes.t -> int -> int64 +val benat_to_cpu: t -> int -> nativeint +val cpu_to_benat: t -> int -> nativeint -> unit diff --git a/common/digestif_bytes.ml b/src/digestif_bytes.ml similarity index 100% rename from common/digestif_bytes.ml rename to src/digestif_bytes.ml diff --git a/src/digestif_bytes.mli b/src/digestif_bytes.mli new file mode 100644 index 0000000..c248c2a --- /dev/null +++ b/src/digestif_bytes.mli @@ -0,0 +1,50 @@ +type t = Bytes.t +val length: t -> int +val create: int -> t +val get: t -> int -> char +val set: t -> int -> char -> unit +val sub: t -> int -> int -> t +val init: int -> (int -> char) -> t +val fill: t -> int -> int -> char -> unit +val copy: t -> t +val get_u8: t -> int -> int +external get_u16: t -> int -> int = "%caml_string_get16u" +external get_u32: t -> int -> int32 = "%caml_string_get32u" +external get_u64: t -> int -> int64 = "%caml_string_get64u" +val get_nat: t -> int -> nativeint +val set_u8: t -> int -> int -> unit +external set_u16: t -> int -> int -> unit = "%caml_string_set16u" +external set_u32: t -> int -> int32 -> unit = "%caml_string_set32u" +external set_u64: t -> int -> int64 -> unit = "%caml_string_set64u" +val set_nat: t -> int -> nativeint -> unit +val to_string: t -> string +val blit: t -> int -> t -> int -> int -> unit +val blit_from_bytes: bytes -> int -> t -> int -> int -> unit +val blit_from_bigstring: Digestif_bigstring.t -> int -> t -> int -> int -> unit +val rpad: t -> int -> char -> t +val compare: t -> t -> int +val eq: t -> t -> bool +val neq: t -> t -> bool +val iter: (char -> unit) -> t -> unit +val empty: t +external swap32: int32 -> int32 = "%bswap_int32" +external swap64: int64 -> int64 = "%bswap_int64" +external swapnat: nativeint -> nativeint = "%bswap_native" +val cpu_to_be32: t -> int -> int32 -> unit +val cpu_to_le32: t -> int -> int32 -> unit +val cpu_to_be64: t -> int -> int64 -> unit +val cpu_to_le64: t -> int -> int64 -> unit +val be32_to_cpu: t -> int -> int32 +val be32_from_bigstring_to_cpu: Digestif_bigstring.t -> int -> int32 +val be32_from_bytes_to_cpu: Bytes.t -> int -> int32 +val le32_to_cpu: t -> int -> int32 +val le32_from_bigstring_to_cpu: Digestif_bigstring.t -> int -> int32 +val le32_from_bytes_to_cpu: Bytes.t -> int -> int32 +val be64_to_cpu: t -> int -> int64 +val be64_from_bigstring_to_cpu: Digestif_bigstring.t -> int -> int64 +val be64_from_bytes_to_cpu: Bytes.t -> int -> int64 +val le64_to_cpu: t -> int -> int64 +val le64_from_bigstring_to_cpu: Digestif_bigstring.t -> int -> int64 +val le64_from_bytes_to_cpu: Bytes.t -> int -> int64 +val benat_to_cpu: t -> int -> nativeint +val cpu_to_benat: t -> int -> nativeint -> unit diff --git a/common/digestif_pp.ml b/src/digestif_pp.ml similarity index 98% rename from common/digestif_pp.ml rename to src/digestif_pp.ml index 62a4581..df2e4c9 100644 --- a/common/digestif_pp.ml +++ b/src/digestif_pp.ml @@ -13,8 +13,7 @@ sig val digest_size : int end -module Make (S : B) (D : D) = -struct +module Make (S : B) (D : D) = struct let to_hex hash = let res = S.create (D.digest_size * 2) in @@ -69,4 +68,3 @@ struct for i = 0 to D.digest_size - 1 do Format.fprintf fmt "%02x" (Char.code (S.get hash i)) done end - diff --git a/src/digestif_pp.mli b/src/digestif_pp.mli new file mode 100644 index 0000000..01e24da --- /dev/null +++ b/src/digestif_pp.mli @@ -0,0 +1,19 @@ +module type B = sig + type t + + val create : int -> t + val iter : (char -> unit) -> t -> unit + val set : t -> int -> char -> unit + val get : t -> int -> char +end + +module type D = sig + val digest_size : int +end + +module Make (S : B) (D : D): sig + val to_hex : S.t -> S.t + val fold_s : ('a -> char -> 'a) -> 'a -> S.t -> 'a + val of_hex : S.t -> S.t + val pp : Format.formatter -> S.t -> unit +end diff --git a/common/digestif.mli b/src/digestif_sig.mli similarity index 55% rename from common/digestif.mli rename to src/digestif_sig.mli index c1eab89..91041a5 100644 --- a/common/digestif.mli +++ b/src/digestif_sig.mli @@ -1,19 +1,19 @@ -module Bi : module type of Digestif_bigstring +module Bigstring = Digestif_bigstring +module Bytes = Digestif_bytes + +module type S = sig -module type S = -sig val digest_size : int - module Bigstring : - sig - type buffer = Bi.t + module Bigstring: sig + type buffer = Bigstring.t type ctx - type t = Bi.t + type t = Bigstring.t val init : unit -> ctx val feed : ctx -> buffer -> unit val feed_bytes : ctx -> Bytes.t -> unit - val feed_bigstring : ctx -> Bi.t -> unit + val feed_bigstring : ctx -> Bigstring.t -> unit val get : ctx -> t val digest : buffer -> t @@ -30,8 +30,7 @@ sig val to_hex : t -> buffer end - module Bytes : - sig + module Bytes: sig type buffer = Bytes.t type ctx type t = Bytes.t @@ -39,7 +38,7 @@ sig val init : unit -> ctx val feed : ctx -> buffer -> unit val feed_bytes : ctx -> Bytes.t -> unit - val feed_bigstring : ctx -> Bi.t -> unit + val feed_bigstring : ctx -> Bigstring.t -> unit val get : ctx -> t val digest : buffer -> t @@ -57,16 +56,6 @@ sig end end -module MD5 : S -module SHA1 : S -module SHA224 : S -module SHA256 : S -module SHA384 : S -module SHA512 : S -module BLAKE2B : S -module BLAKE2S : S -module RMD160 : S - type hash = [ `MD5 | `SHA1 @@ -78,28 +67,15 @@ type hash = | `BLAKE2S | `RMD160 ] -module Bytes : -sig - val digest : hash -> Bytes.t -> Bytes.t - val digestv : hash -> Bytes.t list -> Bytes.t - val mac : hash -> key:Bytes.t -> Bytes.t -> Bytes.t - val macv : hash -> key:Bytes.t -> Bytes.t list -> Bytes.t - - val pp : hash -> Format.formatter -> Bytes.t -> unit - val of_hex : hash -> Bytes.t -> Bytes.t - val to_hex : hash -> Bytes.t -> Bytes.t +module type T = sig + type t + type buffer + + val pp : hash -> Format.formatter -> t -> unit + val digest : hash -> buffer -> t + val digestv : hash -> buffer list -> t + val mac : hash -> key:buffer -> buffer -> t + val macv : hash -> key:buffer -> buffer list -> t + val of_hex : hash -> buffer -> t + val to_hex : hash -> t -> buffer end - -module Bigstring : -sig - val digest : hash -> Bi.t -> Bi.t - val digestv : hash -> Bi.t list -> Bi.t - val mac : hash -> key:Bi.t -> Bi.t -> Bi.t - val macv : hash -> key:Bi.t -> Bi.t list -> Bi.t - - val pp : hash -> Format.formatter -> Bi.t -> unit - val of_hex : hash -> Bi.t -> Bi.t - val to_hex : hash -> Bi.t -> Bi.t -end - -val digest_size : hash -> int diff --git a/test/_tags b/test/_tags new file mode 100644 index 0000000..dc4d280 --- /dev/null +++ b/test/_tags @@ -0,0 +1,3 @@ +true: safe_string, bin_annot + +<*.{ml,mli,byte,native}>: package(fmt), package(alcotest), package(cstruct) diff --git a/digestif-test-c.opam b/test/digestif-test-c.opam similarity index 85% rename from digestif-test-c.opam rename to test/digestif-test-c.opam index cb4fc33..0854c74 100644 --- a/digestif-test-c.opam +++ b/test/digestif-test-c.opam @@ -10,8 +10,9 @@ dev-repo: "https://github.com/mirage/digestif.git" doc: "https://mirage.github.io/digestif/" license: "MIT" -build: [ "ocamlbuild" "-use-ocamlfind" "-package" "digestif.c" "test/test.native" ] -build-test: [ "./test.native" ] +build: + [ [ "ocamlbuild" "-use-ocamlfind" "-package" "digestif.c" "test.native" ] + [ "./test.native" ] ] depends: [ "ocamlbuild" {build} diff --git a/digestif-test-ocaml.opam b/test/digestif-test-ocaml.opam similarity index 85% rename from digestif-test-ocaml.opam rename to test/digestif-test-ocaml.opam index 2e48585..101f108 100644 --- a/digestif-test-ocaml.opam +++ b/test/digestif-test-ocaml.opam @@ -10,8 +10,9 @@ dev-repo: "https://github.com/mirage/digestif.git" doc: "https://mirage.github.io/digestif/" license: "MIT" -build: [ "ocamlbuild" "-use-ocamlfind" "-package" "digestif.ocaml" "test/test.native" ] -build-test: [ "./test.native" ] +build: + [ [ "ocamlbuild" "-use-ocamlfind" "-package" "digestif.ocaml" "test.native" ] + [ "./test.native" ] ] depends: [ "ocamlbuild" {build} diff --git a/test/test.ml b/test/test.ml index c377a39..167c5ec 100644 --- a/test/test.ml +++ b/test/test.ml @@ -53,7 +53,7 @@ module Bi (Hash : HASH) = struct type t = bigstring - let eq = Digestif.Bi.eq + let eq = Digestif_bigstring.eq let pp = Digestif.Bigstring.pp Hash.v end @@ -104,9 +104,9 @@ let makes ~name buffer hash keys inputs expects = let to_bigstring s = let ln = Bytes.length s in - let bi = Digestif.Bi.create ln in + let bi = Digestif_bigstring.create ln in - Digestif.Bi.blit_from_bytes s 0 bi 0 ln; + Digestif_bigstring.blit_from_bytes s 0 bi 0 ln; bi let keys_by, keys_bi = @@ -226,8 +226,8 @@ let results_blake2s_by, results_blake2s_bi = module BLAKE2 = struct - let input_blake2b_file = "./test/blake2b.test" - let input_blake2s_file = "./test/blake2s.test" + let input_blake2b_file = "./blake2b.test" + let input_blake2s_file = "./blake2s.test" let fold_s f a s = let r = ref a in @@ -361,7 +361,7 @@ struct List.map (fun (input, expect) -> make_digest ~name:"rmd160" Bytes `RMD160 input expect) (List.combine (List.map Bytes.unsafe_of_string inputs) (List.map (BLAKE2.of_hex Digestif.RMD160.digest_size) expects)) @ [ million "(bytes)" (module Digestif.RMD160.Bytes : D with type t = Bytes.t) (module By) ~expect:expect_million_y - ; million "(bigstring)" (module Digestif.RMD160.Bigstring : D with type t = bigstring) (module Digestif.Bi) ~expect:expect_million_i ] + ; million "(bigstring)" (module Digestif.RMD160.Bigstring : D with type t = bigstring) (module Digestif_bigstring) ~expect:expect_million_i ] end let tests () =