diff options
Diffstat (limited to 'lib/bindings.ml')
-rw-r--r-- | lib/bindings.ml | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/lib/bindings.ml b/lib/bindings.ml index 61f65cd..7f6cb76 100644 --- a/lib/bindings.ml +++ b/lib/bindings.ml @@ -191,6 +191,16 @@ let trim_tree c_ptr_l c_ptr_r = | CD.Incommensurable -> error_message := "Incommensurable"; Ctypes.null | CD.Empty_comparison -> error_message := "Empty comparison"; Ctypes.null +let show_diff cmds path c_ptr_l c_ptr_r = + let path = split_on_whitespace path in + let ct_l = Root.get c_ptr_l in + let ct_r = Root.get c_ptr_r in + try + CD.show_diff ~cmds:cmds path ct_l ct_r + with + | CD.Incommensurable -> error_message := "Incommensurable"; "#1@" + | CD.Empty_comparison -> error_message := "Empty comparison"; "#1@" + module Stubs(I : Cstubs_inverted.INTERNAL) = struct @@ -218,4 +228,5 @@ struct let () = I.internal "return_values" ((ptr void) @-> string @-> returning string) return_values let () = I.internal "diff_tree" (string @-> (ptr void) @-> (ptr void) @-> returning (ptr void)) diff_tree let () = I.internal "trim_tree" ((ptr void) @-> (ptr void) @-> returning (ptr void)) trim_tree + let () = I.internal "show_diff" (bool @-> string @-> (ptr void) @-> (ptr void) @-> returning string) show_diff end |