Perf: Implement a new algorithm for pattern matching compilation to reduce code size
Compare changes
+ 207
− 44
@@ -13,6 +13,7 @@ module O = Ast_expanded
@@ -25,11 +26,18 @@ type signature = LabelSet.t
@@ -38,6 +46,13 @@ let print_matrix : matrix -> unit =
@@ -47,18 +62,72 @@ let print_matrix : matrix -> unit =
@@ -69,13 +138,6 @@ let get_signature_of_sum_type : I.type_expression -> signature =
@@ -91,26 +153,28 @@ let rec to_simple_pattern
@@ -128,14 +192,49 @@ let rec to_simple_pattern
@@ -150,7 +249,8 @@ let default : matrix -> matrix =
@@ -170,12 +270,15 @@ let has_all_var_pattersn : simple_pattern list -> bool =
@@ -186,16 +289,18 @@ let remove_first_column : row -> row =
@@ -238,8 +343,31 @@ let swap_column_in_matrix : int -> matrix -> matrix =
@@ -256,20 +384,36 @@ let rec compile : matrix -> decision_tree =
@@ -284,10 +428,29 @@ let test